Rumah >hujung hadapan web >tutorial js >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.
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:
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:
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) );
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:
npm init
npm install express ejs nodemailer mysql body-parser express-session --save
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'); });
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!