婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁(yè) > 知識(shí)庫(kù) > Node后端Express框架安裝及應(yīng)用

Node后端Express框架安裝及應(yīng)用

熱門標(biāo)簽:400電話辦理費(fèi)用低 谷歌地圖標(biāo)注日期 外呼系統(tǒng)怎么群發(fā)短信 宿遷怎么辦理400電話 蘇州呼叫中心外呼系統(tǒng)哪家強(qiáng) 地圖標(biāo)注項(xiàng)目幾個(gè)月 400電話申請(qǐng)到底哪家好 鶴壁高頻外呼系統(tǒng)多少錢一個(gè)月 聯(lián)通外呼系統(tǒng)電腦app軟件

Express 框架核心特性:

  • 可以設(shè)置中間件來(lái)響應(yīng) HTTP 請(qǐng)求。
  • 定義了路由表用于執(zhí)行不同的 HTTP 請(qǐng)求動(dòng)作。
  • 可以通過(guò)向模板傳遞參數(shù)來(lái)動(dòng)態(tài)渲染 HTML 頁(yè)面。

Express安裝

express的使用過(guò)程有兩種方式:

  •  方式一:通過(guò)express提供的腳手架,直接創(chuàng)建一個(gè)應(yīng)用的骨架;
  • 方式二:從零搭建自己的express應(yīng)用結(jié)構(gòu);

方式一:安裝express-generator

npm install -g express-generator

創(chuàng)建項(xiàng)目

express express-app

項(xiàng)目目錄如下

├── app.js
├── bin
│   └── www
├── package-lock.json
├── package.json
├── public
│   ├── images
│   ├── javascripts
│   └── stylesheets
│       └── style.css
├── routes
│   ├── index.js
│   └── users.js
└── views
    ├── error.jade
    ├── index.jade
    └── layout.jade

之后 cd 進(jìn)入到對(duì)應(yīng)的目錄下,然后將項(xiàng)目跑起來(lái):

npm install 
node bin/www
node app.js   

方式二: 自己搭建環(huán)境

上面通過(guò)express提供的腳手架,直接創(chuàng)建一個(gè)應(yīng)用的骨架;現(xiàn)在我們自己從零搭建項(xiàng)目:

初始化一個(gè)新的項(xiàng)目:

npm init -y

安裝express:

npm install express

新建app.js

express 初體驗(yàn)

現(xiàn)在搭建自己的第一個(gè)express程序:在app.js中加入如下代碼

const express = require('express');
// 創(chuàng)建服務(wù)器
const app = express();
app.get('/',(req,res) => {
  res.end("Hello World");
});
app.listen(8000,() => {
  console.log("服務(wù)器啟動(dòng)成功~");
})

進(jìn)入項(xiàng)目根目錄下,在終端中將服務(wù)器跑起來(lái):

node app.js

到瀏覽器:訪問(wèn)localhost:8000即可

請(qǐng)求和響應(yīng)

請(qǐng)求的路徑中如果有一些參數(shù),可以這樣表達(dá):

/users/:userId

request對(duì)象中要獲取可以通過(guò)req.params.userId;

返回?cái)?shù)據(jù)

返回?cái)?shù)據(jù),我們可以方便的使用json

res.json(數(shù)據(jù))方式;

const express = require('express');
const app = express();
app.get('/users/:userId', (req, res, next) => {
  console.log(req.params.userId);
  res.json({username: "liyingxia", password: "8i8i8i8i" });
});
app.listen(8000, () => {
  console.log("靜態(tài)服務(wù)器啟動(dòng)成功~");
})

Express 中間件

認(rèn)識(shí)中間件

Express是一個(gè)路由和中間件的Web框架,它本身的功能非常少:

Express應(yīng)用程序本質(zhì)上是一系列中間件函數(shù)的調(diào)用;

中間是什么?

中間件的本質(zhì)就是一個(gè)回調(diào)函數(shù);

這個(gè)回調(diào)函數(shù)接受三個(gè)參數(shù):

請(qǐng)求對(duì)象(request對(duì)象);

響應(yīng)對(duì)象(response對(duì)象);

next函數(shù)(在express中定義的用于執(zhí)行下一個(gè)中間件的函數(shù));

中間件中可以執(zhí)行哪些任務(wù)?

執(zhí)行任何代碼;

更改請(qǐng)求(request)和響應(yīng)(response)對(duì)象;

結(jié)束請(qǐng)求-響應(yīng)周期(返回?cái)?shù)據(jù));

調(diào)用棧中的下一個(gè)中間件;

如果當(dāng)前中間件功能沒(méi)有結(jié)束請(qǐng)求-響應(yīng)周期,則必須調(diào)用 next()將控制權(quán)傳遞給下一個(gè)中間件功能,否則,請(qǐng)求將被掛起。

使用中間件

express主要提供了兩種方式:app/router.useapp/router.methods這兩種方式把中間件應(yīng)用到我們的應(yīng)用程序中;

methods指的是常用的請(qǐng)求方式,比如:app.getapp.post

// express 中間件的使用
const express = require('express');
const res = require('express/lib/response');
const app = express();
app.use((req,res,next) => {
  console.log("middleware");
  next();
});
app.use((req,res,next) => {
  console.log("middleware");
  res.end("Hello Common Middleware");
})
app.listen(9000,()=>{
  console.log("中間件服務(wù)器啟動(dòng)成功~")
})

path匹配中間件:

//path 路徑匹配中間件
app.use('/home',(req,res,next) => {
  console.log("home middleware 中間件");
  next();
});
app.use('/home',(req,res,next) => {
  console.log("home middleware02");
  next();
  res.end("middleware");
});
app.use((req,res,next) =>{
   console.log("middleware");
})

path 和 method 匹配中間件

// path 和 method 匹配中間件
app.get('/home',(req,res,next) => {
  console.log("home get middleware");
  next();
})
app.post('/login',(req,res,next) => {
  console.log("login post middleware");
  next();
});
app.use((req,res,next) => {
  console.log("common middleware");
})
app.use(express.json());
app.use(express.urlencoded({extended:true}));
app.post('/login',(req,res,next) => {
  console.log(req.body);
  res.end("登陸成功~");
});

日志記錄中間件

如果我們希望將請(qǐng)求日志記錄下來(lái),那么可以使用express官網(wǎng)開(kāi)發(fā)的第三方庫(kù):morgan
morgan安裝:

npm install morgan

如何用?直接作為中間件使用即可:

const loggerWriter = fs.createWriteStream('./log/access.log', {
  flags: 'a+'
})
app.use(morgan('combined', {stream: loggerWriter}));

上傳文件中間件

圖片上傳我們可以使用express官方開(kāi)發(fā)的第三方庫(kù):multer

multer安裝:

npm install multer

上傳文件:

const upload = multer({
  dest: "uploads/"
})

app.post('/upload', upload.single('file'), (req, res, next) => {
  console.log(req.file.buffer);
  res.end("文件上傳成功~");
})

添加上傳文件后綴名:

const storage = multer.diskStorage({
  destination: (req, file, cb) => {
    cb(null, "uploads/")
  },
  filename: (req, file, cb) => {
    cb(null, Date.now() + path.extname(file.originalname));
  }
})
const upload = multer({
  storage
})
app.post('/upload', upload.single('file'), (req, res, next) => {
  console.log(req.file.buffer);
  res.end("文件上傳成功~");
})

上傳多張圖片:

app.use('/upload', upload.array('files'), (req, res, next) => {
  console.log(req.files);
});

請(qǐng)求和響應(yīng)

客戶端傳遞到服務(wù)器參數(shù)的方法常見(jiàn)的是5種:

方式一:通過(guò)get請(qǐng)求中的URL的params;

方式二:通過(guò)get請(qǐng)求中的URL的query;

方式三:通過(guò)post請(qǐng)求中的body的json格式;

方式四:通過(guò)post請(qǐng)求中的body的x-www-form-urlencoded格式;

方式五:通過(guò)post請(qǐng)求中的form-data格式;

請(qǐng)求解析

方式一:params

請(qǐng)求地址: http://locahost:8000/login/asd/ass

獲取參數(shù):

app.use('/login/:id/:name', (req, res, next) => {
  console.log(req.params);
  res.json("請(qǐng)求成功~");
})

方式二:query

請(qǐng)求地址:http://localhost:8000/login?username=liyingxiapassword=123456
獲取參數(shù):

app.use('/login', (req, res, next) => {
  console.log(req.query);
  res.json("請(qǐng)求成功~");
})

方式三:通過(guò)post請(qǐng)求中的body的json格式;

在客戶端發(fā)送post請(qǐng)求時(shí),會(huì)將數(shù)據(jù)放到body中:客戶端可以通過(guò)json的方式傳遞,也可以通過(guò)form表單的方式傳遞;

自己編寫(xiě)中間件來(lái)解析JSON:

app.use((req, res, next) => {
  if (req.headers['content-type'] === 'application/json') {
    req.on('data', (data) => {
      const userInfo = JSON.parse(data.toString());
      req.body = userInfo;
    })
    req.on('end', () => {
      next();
    })
  } else {
    next();
  }
})
app.post('/login', (req, res, next) => {
  console.log(req.body);
  res.end("登錄成功~");
});

適用express內(nèi)置的中間件或者使用body-parser來(lái)完成:

app.use(express.json());
app.post('/login', (req, res, next) => {
  console.log(req.body);
  res.end("登錄成功~");
});

方式四:通過(guò)post請(qǐng)求中

body的x-www-form-urlencoded格式;

解析application/x-www-form-urlencoded:

可以使用express自帶的 urlencoded函數(shù)來(lái)作為中間件:

傳入的extended用于表示使用哪一種解析方式:

  • true:使用qs第三方模塊;
  • false:使用querystring內(nèi)置模塊;
app.use(express.json());
app.use(express.urlencoded({extended: true}));

app.post('/login', (req, res, next) => {
  console.log(req.body);
  res.end("登錄成功~");
});

方式五:通過(guò)post請(qǐng)求中的form-data格式;

通過(guò)any借助multer去解析一些form-data中的普通數(shù)據(jù):

app.use(upload.any());
app.use('/login', (req, res, next) => {
  console.log(req.body);
});

響應(yīng)方式

end()類似于http中的response.end方法;

res.end("獲取成功~")

json()json方法中可以傳入很多的類型:

object、array、string、boolean、number、null等,都會(huì)被轉(zhuǎn)換成json格式返回

res.json({name:"liyignxia",password:"123456"});

status()設(shè)置狀態(tài)碼

res.status(200);

路由的使用

使用express.Router來(lái)創(chuàng)建一個(gè)路由處理程序:一個(gè)Router實(shí)例擁有完整的中間件和路由系統(tǒng);

// 用戶相關(guān)的處理
const userRouter = express.Router();

userRouter.get('/', (req, res, next) => {
  res.end("用戶列表");
});

userRouter.post('/', (req, res, next) => {
  res.end("創(chuàng)建用戶");
});

userRouter.delete('/', (req, res, next) => {
  res.end("刪除用戶");
});

app.use('/users', userRouter);

靜態(tài)資源服務(wù)器

Node也可以作為靜態(tài)資源服務(wù)器,并且express給我們提供了方便部署靜態(tài)資源的方法;

const express = require('express');
const app = express();
app.use(express.static('./build'));
app.listen(8000, () => {
  console.log("靜態(tài)服務(wù)器啟動(dòng)成功~");
})

錯(cuò)誤處理方式

app.use((req, res, next) => {
  next(new Error("USER DOES NOT EXISTS"));
});
app.use((err, req, res, next) => {
  const message = err.message;
  switch (message) {
    case "USER DOES NOT EXISTS":
      res.status(400).json({message})
  }
  res.status(500)
})
您可能感興趣的文章:
  • node+express框架中連接使用mysql(經(jīng)驗(yàn)總結(jié))
  • NodeJs中express框架的send()方法簡(jiǎn)介
  • Node.js的Express框架使用上手指南
  • Nodejs express框架一個(gè)工程中同時(shí)使用ejs模版和jade模版
  • NodeJS Express框架中處理404頁(yè)面一個(gè)方式

標(biāo)簽:雙鴨山 錫林郭勒盟 襄陽(yáng) 莆田 遵義 鄂爾多斯 丹東 哈爾濱

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Node后端Express框架安裝及應(yīng)用》,本文關(guān)鍵詞  Node,后端,Express,框架,安裝,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Node后端Express框架安裝及應(yīng)用》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于Node后端Express框架安裝及應(yīng)用的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    精品视频一区 二区 三区| 国产乱对白刺激视频不卡| 老司机免费视频一区二区| 欧美自拍偷拍一区| 亚洲视频在线观看三级| 成人一区在线观看| 久久精品免视看| 国内欧美视频一区二区| 日本一二三四高清不卡| 在线观看亚洲一区| 亚洲制服丝袜在线| 欧美日韩一区二区三区四区五区| 亚洲欧美电影院| 欧美午夜一区二区三区| 日本在线播放一区二区三区| 欧美精品一区二区蜜臀亚洲| 国产成人高清在线| 亚洲免费在线播放| 欧美久久久久中文字幕| 精品一区二区av| 中文字幕亚洲成人| 欧美日韩国产综合一区二区| 国产精品一级二级三级| 亚洲免费观看在线视频| 欧美大片一区二区| 成人av免费在线播放| 欧美国产精品一区| 欧美最猛黑人xxxxx猛交| 麻豆91免费看| 一区二区激情视频| 亚洲精品一区二区三区精华液 | 免费在线视频一区| 中文久久乱码一区二区| 欧美手机在线视频| 国产suv精品一区二区三区| 一区二区三区毛片| 欧美国产精品一区二区三区| 精品视频在线免费看| www.日韩在线| 国产精品18久久久久久久久久久久 | 懂色av一区二区三区蜜臀| 亚洲精品一二三区| 久久久久久久久久电影| 欧美无乱码久久久免费午夜一区| 国内精品视频一区二区三区八戒| 国产精品久久精品日日| 欧美成人一级视频| 欧美精品久久久久久久多人混战| 国产成+人+日韩+欧美+亚洲| 激情成人午夜视频| 日韩av电影免费观看高清完整版在线观看| 国产视频一区二区三区在线观看 | 自拍偷在线精品自拍偷无码专区| 91久久精品国产91性色tv| 色综合天天综合网天天看片| 国内一区二区视频| 黄一区二区三区| 精品一区精品二区高清| 久久国产精品99久久人人澡| 亚洲成av人影院在线观看网| 亚洲男女毛片无遮挡| 亚洲国产精品av| 日本一区二区免费在线| 国产日韩欧美激情| 亚洲国产精华液网站w| 欧美精品一区二| 久久网站热最新地址| 久久久久久久免费视频了| 精品少妇一区二区三区视频免付费| 正在播放一区二区| 欧美一区二区三区婷婷月色 | 久久亚洲精品小早川怜子| 日韩精品一区二区三区视频| 精品乱人伦一区二区三区| 精品国产乱码久久久久久老虎| 精品国产三级a在线观看| 精品国产乱码久久久久久久久| 欧美变态tickling挠脚心| 久久亚洲一区二区三区明星换脸| 中文字幕精品一区| 国产精品夫妻自拍| 亚洲已满18点击进入久久| 日韩av在线播放中文字幕| 国产一区二区免费视频| 菠萝蜜视频在线观看一区| 91成人免费电影| 91精品国产综合久久精品麻豆| 欧美精品一区二区三区在线| 国产欧美一区二区三区沐欲| 亚洲日本青草视频在线怡红院| 亚洲国产aⅴ天堂久久| 国产一区二三区| 91福利资源站| 精品99久久久久久| 亚洲综合精品久久| 精品在线亚洲视频| 在线观看一区不卡| 欧美国产1区2区| 青青草97国产精品免费观看无弹窗版| 国产在线视频一区二区三区| 91亚洲精品久久久蜜桃| 日韩精品一区二区三区视频播放| 17c精品麻豆一区二区免费| 日韩综合小视频| 成人午夜视频网站| 777亚洲妇女| 亚洲精品中文在线| 国产成人精品www牛牛影视| 欧美男生操女生| 亚洲欧洲av在线| 精品一二三四在线| 欧美性三三影院| 国产精品国产三级国产aⅴ中文| 青青草97国产精品免费观看无弹窗版 | 午夜成人在线视频| 成人午夜电影小说| 欧美大白屁股肥臀xxxxxx| 亚洲女女做受ⅹxx高潮| 国产99精品国产| 日韩视频在线永久播放| 亚洲午夜av在线| 97精品超碰一区二区三区| 久久久久国产精品人| 蜜桃视频在线观看一区二区| 欧美视频一区二区| 亚洲丝袜精品丝袜在线| 国产91精品精华液一区二区三区| 日韩精品一区在线观看| 五月婷婷激情综合| 欧美吞精做爰啪啪高潮| 亚洲一区国产视频| 日本韩国精品一区二区在线观看| 国产精品国产三级国产| 国产.欧美.日韩| 国产校园另类小说区| 国产精品亚洲综合一区在线观看| 久久这里只有精品6| 国产在线不卡一区| 国产日韩精品视频一区| 成人中文字幕电影| 亚洲人成网站影音先锋播放| 91麻豆精品视频| 亚洲国产另类av| 欧美日本乱大交xxxxx| 亚洲gay无套男同| 欧美一区二区三区免费视频| 男人的天堂亚洲一区| 精品国产一二三| 国产激情91久久精品导航| 中文字幕av资源一区| 成人在线综合网| 综合久久国产九一剧情麻豆| 色综合天天综合色综合av| 亚洲二区在线视频| 欧美电影免费提供在线观看| 国产在线精品一区二区夜色| 久久亚洲精精品中文字幕早川悠里| 国产在线不卡视频| 亚洲日本成人在线观看| 欧美日韩第一区日日骚| 美女被吸乳得到大胸91| 中文一区一区三区高中清不卡| 一本到不卡精品视频在线观看 | 美女国产一区二区三区| 久久久亚洲欧洲日产国码αv| 粉嫩蜜臀av国产精品网站| 日韩毛片在线免费观看| 欧美日韩夫妻久久| 韩国av一区二区三区| 中文字幕在线不卡一区| 欧美日韩国产色站一区二区三区| 青娱乐精品视频| 一区二区中文字幕在线| 欧美肥大bbwbbw高潮| 成人av影院在线| 婷婷成人综合网| 国产精品美女www爽爽爽| 欧美日韩你懂的| 国产一区二区中文字幕| 亚洲一区二区在线观看视频| 26uuu久久天堂性欧美| 色就色 综合激情| 国内精品久久久久影院色| 亚洲欧美日韩精品久久久久| 2024国产精品| 欧美精品1区2区3区| 99麻豆久久久国产精品免费优播| 日韩中文字幕一区二区三区| 综合久久一区二区三区| 欧美一区二区在线播放| gogogo免费视频观看亚洲一| 精品一区在线看| 偷窥少妇高潮呻吟av久久免费| 亚洲欧洲日本在线| 国产女同性恋一区二区| 69av一区二区三区| 在线日韩av片| 91丝袜美腿高跟国产极品老师| 国产一区二区伦理片| 蜜桃久久久久久久|