1. 程式人生 > 實用技巧 >node中介軟體有哪些型別?

node中介軟體有哪些型別?

node中介軟體就是封裝在程式中處理http請求的功能。node中介軟體是在管道中執行。中介軟體位於客戶機/ 伺服器的作業系統之上,管理計算機資源和網路通訊。

中介軟體為主要的邏輯業務所服務,可分為:應用級中介軟體、路由級中介軟體、內建中介軟體、第三方中介軟體、錯誤級中介軟體。

1、應用級中介軟體

每一箇中間件就是呼叫一個函式,需要配合其他的中介軟體或者路由使用

server (函式) 攔截所有的路由

server.use('/reg',函式);攔截特定的路由

const express=require('express');
var server=express();
server.listen(3000);
//中介軟體攔截註冊路由/reg
server.use('/reg',(req,res,next)=>{
    console.log('註冊驗證');
    next();
});

server.use('/login',(req,res)=>{
    console.log('記錄了日誌');
})
server.get('/reg',(req,res,next)=>{
    res.send('註冊成功');
    next();
});

server.get('/login',(req,res)=>{
    res.send('登陸成功');
})

2、內建中介軟體

server.use(express.static('目錄'))

把靜態資原始檔託管到某一個目錄,如果瀏覽器請求靜態資源,則自動到這個目錄下查詢

佛山vi設計https://www.houdianzi.com/fsvi/ 豌豆資源搜尋大全https://55wd.com

3、第三方中介軟體

(1)body-parser,將post請求資料解析為物件

const express = require('express');
//引入body-parser中介軟體
const bodyParser=require('body-parser');

var server=express();
server.listen(3000);
// 託管靜態資源到public
server.use(express.static('./public'));

//使用body-parser中介軟體,將post請求的資料
解析為物件 //extended是否要使用擴充套件qs模組解析為物件 //如果是false,不使用,而去使用querystring模組 server.use(bodyParser.urlencoded( {extended:false} )) server.post('/mylogin',(req,res)=>{ console.log(req.body); res.send('登陸成功'); })

(2)mysql模組

普通連線

//引入mysql模組
const mysql =require('mysql');
//1、普通連線
//1、1建立連線
var connection=mysql.createConnection({
    host:'127.0.0.1',
    port:'3306',
    user:'root',
    password:'1234',
    database:'tedu'
});
//1.2執行連線
connection.connect();
//執行sql語句
connection.query('select * from emp',(err,result)=>{
    if(err) throw err;
    console.log(result);
});
//關閉連線
connection.end();

連線池

const mysql=require('mysql');
//使用連線池
//建立連線池物件
var pool=mysql.createPool(
    {
        host:'127.0.0.1',
        port:'3306',
        user:'root',
        password:'1234',
        database:'tedu',
        connectionLimit:20
    }
);
//執行sql語句
pool.query('select * from emp where eid=2',(err,result)=>{
    if(err) throw err;
    console.log(result);
})
const mysql=require('mysql');
var pool=mysql.createPool({
    'host':'127.0.0.1',
    port:'3306',
    user:'root',
    password:'1234',
    database:'tedu',
    connectionLimit:20
})
//使用佔位符插入資料
// pool.query("insert into emp values(?,?,?,?,?,?)",[null,'yt','1','1995-12-24','9000','20'],(err,result)=>{
//     if(err) throw err;
//     console.log(result);
// });
//使用物件插入資料
// var emp={
//     eid:null,
//     ename:'html',
//     sex:1,
//     birthday:'1995-12-25',
//     salary:10000,
//     deptid:30
// }
// pool.query('insert into emp set ?',[emp],(err,result)=>{
//     if(err) throw err;
//     console.log(result);
// })
//使用佔位符刪除編號為10的資料
pool.query('delete  from emp where eid=?',[10],(err,result)=>{
    if(err) throw err;
    console.log(result);
    if(result.affectedRows>0){
        console.log('刪除成功');
    }
    else{
        console.log('刪除失敗');
    }
})