


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.
- 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.
- 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) );
- 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:
- Buka gesaan atau terminal dan tukar ke folder "AppointmentSystem".
- Jalankan arahan berikut:
npm init
- Jawab semua soalan gesaan menggunakan nilai lalai untuk melengkapkan penciptaan fail "package.json".
- 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.
- 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'); });
- 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!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Tempat projek Eclipse disimpan bergantung pada jenis projek dan tetapan ruang kerja. Projek Java: Disimpan dalam folder projek dalam ruang kerja. Projek web: disimpan dalam folder projek dalam ruang kerja, dibahagikan kepada berbilang subfolder. Jenis projek lain: Fail disimpan dalam folder projek dalam ruang kerja dan organisasi mungkin berbeza-beza bergantung pada jenis projek. Lokasi ruang kerja terletak dalam "<direktori rumah>/ruang kerja" secara lalai dan boleh ditukar melalui pilihan Eclipse. Untuk mengubah suai lokasi storan projek, klik kanan projek dan pilih tab Sumber dalam Properties.

Node.js boleh digunakan sebagai rangka kerja bahagian belakang kerana ia menawarkan ciri seperti prestasi tinggi, kebolehskalaan, sokongan merentas platform, ekosistem yang kaya dan kemudahan pembangunan.

Untuk menyambung ke pangkalan data MySQL, anda perlu mengikuti langkah berikut: Pasang pemacu mysql2. Gunakan mysql2.createConnection() untuk mencipta objek sambungan yang mengandungi alamat hos, port, nama pengguna, kata laluan dan nama pangkalan data. Gunakan connection.query() untuk melaksanakan pertanyaan. Akhir sekali gunakan connection.end() untuk menamatkan sambungan.

Pembolehubah global berikut wujud dalam Node.js: Objek global: modul Teras global: proses, konsol, memerlukan pembolehubah persekitaran Runtime: __dirname, __filename, __line, __column Constants: undefined, null, NaN, Infinity, -Infinity

Terdapat dua fail berkaitan npm dalam direktori pemasangan Node.js: npm dan npm.cmd Perbezaannya adalah seperti berikut: sambungan berbeza: npm ialah fail boleh laku dan npm.cmd ialah pintasan tetingkap arahan. Pengguna Windows: npm.cmd boleh digunakan daripada command prompt, npm hanya boleh dijalankan dari baris arahan. Keserasian: npm.cmd adalah khusus untuk sistem Windows, npm tersedia merentas platform. Cadangan penggunaan: Pengguna Windows menggunakan npm.cmd, sistem pengendalian lain menggunakan npm.

Perbezaan utama antara Node.js dan Java ialah reka bentuk dan ciri: Didorong peristiwa vs. didorong benang: Node.js dipacu peristiwa dan Java dipacu benang. Satu-benang vs. berbilang benang: Node.js menggunakan gelung acara satu-benang dan Java menggunakan seni bina berbilang benang. Persekitaran masa jalan: Node.js berjalan pada enjin JavaScript V8, manakala Java berjalan pada JVM. Sintaks: Node.js menggunakan sintaks JavaScript, manakala Java menggunakan sintaks Java. Tujuan: Node.js sesuai untuk tugas intensif I/O, manakala Java sesuai untuk aplikasi perusahaan besar.

Ya, Node.js ialah bahasa pembangunan bahagian belakang. Ia digunakan untuk pembangunan bahagian belakang, termasuk mengendalikan logik perniagaan sebelah pelayan, mengurus sambungan pangkalan data dan menyediakan API.

Langkah-langkah penggunaan pelayan untuk projek Node.js: Sediakan persekitaran penggunaan: dapatkan akses pelayan, pasang Node.js, sediakan repositori Git. Bina aplikasi: Gunakan npm run build untuk menjana kod dan kebergantungan yang boleh digunakan. Muat naik kod ke pelayan: melalui Git atau Protokol Pemindahan Fail. Pasang kebergantungan: SSH ke dalam pelayan dan gunakan pemasangan npm untuk memasang kebergantungan aplikasi. Mulakan aplikasi: Gunakan arahan seperti node index.js untuk memulakan aplikasi, atau gunakan pengurus proses seperti pm2. Konfigurasikan proksi terbalik (pilihan): Gunakan proksi terbalik seperti Nginx atau Apache untuk menghalakan trafik ke aplikasi anda
