Rumah >hujung hadapan web >tutorial js >Projek web menggunakan Node.js untuk melaksanakan fungsi tempahan dalam talian

Projek web menggunakan Node.js untuk melaksanakan fungsi tempahan dalam talian

王林
王林asal
2023-11-08 16:33:111630semak imbas

Projek web menggunakan Node.js untuk melaksanakan fungsi tempahan dalam talian

Dengan perkembangan Internet yang berterusan, semakin banyak perniagaan mula menggunakan sistem janji temu dalam talian untuk memudahkan pelanggan membuat janji temu dan menguruskan perniagaan. Dalam keadaan ini, projek web yang menggunakan Node.js untuk melaksanakan fungsi tempahan dalam talian secara beransur-ansur menjadi topik hangat.

Dalam artikel ini, kami akan memperkenalkan secara ringkas cara menggunakan Node.js untuk membangunkan sistem janji temu dalam talian berasaskan web, dan memberikan beberapa contoh kod, yang kami harap akan membantu anda memahami sebelum anda mula membuat sistem janji temu dalam talian anda sendiri proses.

  1. Analisis Keperluan

Sebelum membangunkan projek web sedemikian, kami perlu menjalankan analisis keperluan yang teliti. Berikut adalah beberapa fungsi dan ciri perlu yang perlu dilaksanakan dalam projek web ini:

  • Pelanggan boleh melihat dan memilih masa dan perkhidmatan yang tersedia di laman web.
  • Pelanggan boleh memilih bila-bila masa yang sesuai dan menghantar permintaan kepada peniaga.
  • Peniaga boleh melihat permintaan temu janji dan menerima atau menolaknya.
  • Apabila peniaga menerima permintaan tempahan, sistem akan memasukkan maklumat tempahan ke dalam pangkalan data dan menghantar e-mel pengesahan kepada pelanggan.
  • Apabila peniaga menolak permintaan temu janji, sistem akan menghantar e-mel penolakan kepada pelanggan.
  1. Reka Bentuk Pangkalan Data

Dalam contoh ini, kami akan menggunakan pangkalan data MySQL untuk menyimpan maklumat janji temu. Jadual yang dipanggil "Temujanji" perlu dibuat, ia akan mengandungi lajur berikut:

  • ID (pengecam unik) ​​
  • Nama Pelanggan
  • E-mel Pelanggan
  • Jenis Perkhidmatan
  • Tarikh
  • Tarikh
  • Proses Menunggu, Terima atau Tolak)

Berikut ialah pernyataan SQL yang boleh digunakan untuk mencipta jadual ini:

CREATE TABLE Appointments (
  ID INT NOT NULL AUTO_INCREMENT,
  CustomerName VARCHAR(50),
  CustomerEmail VARCHAR(50),
  ServiceType VARCHAR(50),
  AppointmentDate DATE,
  AppointmentTime TIME,
  Status ENUM('Pending', 'Accepted', 'Rejected'),
  PRIMARY KEY (ID)
);
  1. Mencipta aplikasi Node.js

Pertama, kita perlu memasang Node.js pada mesin tempatan kita . Sekarang, kami akan mencipta aplikasi Node.js yang dipanggil "AppointmentSystem".

Buat folder bernama "AppointmentSystem" dan buat fail bernama "app.js" dalam folder. Fail ini akan menjadi fail utama aplikasi Node.js kami dan mengandungi semua kod kami.

Ikuti langkah ini untuk memasang modul Node.js pihak ketiga yang diperlukan:

  1. Buka gesaan atau terminal dan tukar ke folder "AppointmentSystem".
  2. Jalankan arahan berikut: npm init
  3. Jawab semua soalan gesaan menggunakan nilai lalai untuk melengkapkan penciptaan fail "package.json".
  4. Pasang modul berikut:
npm install express ejs nodemailer mysql body-parser express-session --save
  • express: Ini ialah rangka kerja Node.js yang popular untuk membina aplikasi web.
  • ejs: Ini ialah enjin templat yang boleh menjana halaman HTML secara dinamik.
  • nodemailer: Ini ialah modul Node.js untuk menghantar e-mel kepada pelanggan.
  • mysql: Ini ialah modul Node.js yang digunakan untuk menyambung ke pangkalan data MySQL.
  • body-parser: Ini ialah perisian tengah Node.js untuk menghuraikan kandungan permintaan HTTP.
  • express-session: Ini ialah perisian tengah Node.js untuk mengendalikan sesi.
  1. Pelaksanaan Kod

Pertama, kami perlu memperkenalkan semua modul yang baru kami pasang dalam fail utama "app.js" kami:

const express = require('express');
const ejs = require('ejs');
const nodemailer = require('nodemailer');
const mysql = require('mysql');
const bodyParser = require('body-parser');
const session = require('express-session');

const app = express();

Seterusnya, kami perlu mengkonfigurasi aplikasi. Aplikasi kami akan menggunakan folder "paparan" dan "awam" lalai, jadi kami tidak perlu mengkonfigurasinya.

app.set('view engine', 'ejs');
app.use(express.static(__dirname + '/public'));
app.use(bodyParser.urlencoded({extended: true}));
app.use(session({
  secret: 'mysecretkey',
  resave: true,
  saveUninitialized: true
}));

Seterusnya, kita perlu menyambung ke pangkalan data MySQL. Kami akan menggunakan fungsi "createConnection" untuk mencipta sambungan pangkalan data dan kemudian menggunakan objek untuk membuat pertanyaan.

const pool = mysql.createPool({
  host: 'localhost',
  user: 'root',
  password: 'password',
  database: 'appointments'
});

Sekarang, mari tentukan fungsi penghalaan kami Kami menentukan dua laluan, satu untuk mendapatkan borang tempahan dan satu lagi untuk menyerahkan bil laluan.

app.get('/', (req, res) => {
  res.render('index');
});

app.post('/appointment', (req, res) => {
  const {customerName, customerEmail, serviceType, appointmentDate, appointmentTime} = req.body;

  pool.query('INSERT INTO Appointments SET ?', {
    CustomerName: customerName,
    CustomerEmail: customerEmail,
    ServiceType: serviceType,
    AppointmentDate: appointmentDate,
    AppointmentTime: appointmentTime,
    Status: 'Pending'
  }, (error, results) => {
    if (error) {
      throw error;
    } else {
      const transporter = nodemailer.createTransport({
        service: 'gmail',
        auth: {
          user: 'youremail@gmail.com',
          pass: 'yourpassword'
        }
      });
      
      const mailOptions = {
        from: 'youremail@gmail.com',
        to: customerEmail,
        subject: 'Your Appointment Request',
        text: `Dear ${customerName}, 

Thank you for requesting an appointment with our company. We have received your request and will get back to you as soon as possible. 

Best regards, 
The Company`
      };
      
      transporter.sendMail(mailOptions, (error, info) => {
        if (error) {
          throw error;
        } else {
          console.log(`Email sent: ${info.response}`);
        }
      });
      
      res.render('confirmation', {
        customerName,
        customerEmail,
        serviceType,
        appointmentDate,
        appointmentTime
      });
    }
  });
});

Dalam coretan kod di atas, mula-mula kami menggunakan fungsi "pool.query" untuk memasukkan rekod janji temu baharu ke dalam pangkalan data MySQL, dan kemudian mencipta mel Nodemailer untuk menghantar e-mel pengesahan kepada pelanggan. Akhir sekali, kami memberikan butiran pelanggan ke halaman pengesahan supaya mereka boleh melihat butiran janji temu mereka.

Akhir sekali, kami perlu menggunakan fungsi "app.listen" untuk memulakan aplikasi kami dan menyediakan port mendengar.

app.listen(3000, () => {
  console.log('Server started on port 3000');
});
  1. Lancarkan aplikasi

Untuk memulakan pelayan, cuma navigasi ke folder program dalam command prompt atau terminal dan jalankan arahan berikut:

node app.js

Sekarang, buka "localhost" dalam pelayar web anda :3000” untuk digunakan sistem tempahan dalam talian anda.

Atas ialah kandungan terperinci Projek web menggunakan Node.js untuk melaksanakan fungsi tempahan dalam talian. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn