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

Nov 08, 2023 pm 04:33 PM
nodejs Buat temujanji dalam talian projek web

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)
);
Salin selepas log masuk
  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
Salin selepas log masuk
  • 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();
Salin selepas log masuk

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
}));
Salin selepas log masuk

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'
});
Salin selepas log masuk

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
      });
    }
  });
});
Salin selepas log masuk

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');
});
Salin selepas log masuk
  1. Lancarkan aplikasi

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

node app.js
Salin selepas log masuk

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 Laman Web ini
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

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Cara Membuka Segala -galanya Di Myrise
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

lokasi penyimpanan projek gerhana lokasi penyimpanan projek gerhana May 05, 2024 pm 07:36 PM

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.

Adakah nodejs rangka kerja bahagian belakang? Adakah nodejs rangka kerja bahagian belakang? Apr 21, 2024 am 05:09 AM

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.

Bagaimana untuk menyambungkan nodejs ke pangkalan data mysql Bagaimana untuk menyambungkan nodejs ke pangkalan data mysql Apr 21, 2024 am 06:13 AM

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.

Apakah pembolehubah global dalam nodejs Apakah pembolehubah global dalam nodejs Apr 21, 2024 am 04:54 AM

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

Apakah perbezaan antara fail npm dan npm.cmd dalam direktori pemasangan nodejs? Apakah perbezaan antara fail npm dan npm.cmd dalam direktori pemasangan nodejs? Apr 21, 2024 am 05:18 AM

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.

Adakah terdapat perbezaan besar antara nodejs dan java? Adakah terdapat perbezaan besar antara nodejs dan java? Apr 21, 2024 am 06:12 AM

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.

Adakah nodejs bahasa pembangunan bahagian belakang? Adakah nodejs bahasa pembangunan bahagian belakang? Apr 21, 2024 am 05:09 AM

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.

Bagaimana untuk menggunakan projek nodejs ke pelayan Bagaimana untuk menggunakan projek nodejs ke pelayan Apr 21, 2024 am 04:40 AM

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

See all articles