91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

學習使用ExpressJS 4.0中的新Router的用法

發布時間:2020-08-20 00:07:36 來源:腳本之家 閱讀:169 作者:MaxWang 欄目:web開發

概述

ExpressJS 4.0中提出了新的路由Router。Router好比是一個“迷你版”的express應用,它沒有引入views或者settings,但是提供了路由應有的API,.use,.get,.param和route。

示例應用

讓我們創建一個express應用,僅僅有少量routes和功能:

  • 基礎路由:Home,About
  • 一個把request請求打印到console的路由中間件
  • 一個帶參數的路由
  • 一個校驗特殊參數的路由中間件
  • 一個用于登錄的路由,響應對與路徑/login的GET和POST請求
  • 校驗功能:校驗傳遞給某一個路由的參數

應用文件架構

我們只需要兩個文件:

- package.json // 構建node應用所需要的插件
- server.js   // 構建示例應用的啟動文件

我們會把路由代碼寫如server.js文件。將來為了讓示例應用模塊化,我們會把這些路由代碼分別寫入不同的文件,甚至可以為網站的不同組成部分單獨定義不同的路由文件。

創建Node應用

創建node應用,我們需要編寫package.json文件去定義node應用依賴的插件。

{
  "name": "express-router-experiments",
  "main": "server.js",
  "dependencies": {
    "express": "~4.0.0"
  }
}

下面繼續安裝依賴:

$ npm install

現在我們安裝了Express,讓我們繼續編寫server.js去處理路由。

創建server

我們在package.json中指定了main屬性值為server.js,因此Express會使用server.js作為應用的入口文件。

// server.js

// 基礎設置
// ==============================================

var express = require('express');
var app   = express();
var port  =  process.env.PORT || 8080;

// 路由
// ==============================================

// 示例路由
app.get('/sample', function(req, res) {
  res.send('this is a sample!'); 
});

// 我們會在這里編寫自己的路由

// 啟動server
// ==============================================
app.listen(port);
console.log('Magic happens on port ' + port);

現在我們可以使用命令node server.js啟動server。我們使用app.get創建了一個Express 3時代的路由,如果此時打開瀏覽器訪問http://localhost:8080/sample,我們就能看到這樣下面的文字:this is a sample!。

基本用法 express.Router()

下面我們一起編寫Node應用前端路由的例子,包括Home頁面和About頁面。

// server.js

...

// 獲取router實例
var router = express.Router();

// home頁面路由(http://localhost:8080)
router.get('/', function(req, res) {
  res.send('im the home page!'); 
});

// about頁面路由(http://localhost:8080/about)
router.get('/about', function(req, res) {
  res.send('im the about page!'); 
});

// 把定義好的路由集成到Node應用中
app.use('/', router);

...

我們前面的代碼使用express.Router()生成一個路由實例,并定義路由規則,最后把這個路由實例集成到應用中。現在我們可以通過http://localhost:8080訪問Home頁面,通過http://localhost:8080/about訪問about頁面。

請注意:我們可以改變前面定義的路由中默認的根路徑('/')。如果我們把app.use('/', router)改為app.use('/app', router),那么home頁面的訪問地址變為http://localhost:8080/app,about頁面的訪問地址變為http://localhost:8080/app/about。

這是一個非常有用的功能,我們可以利用它創建多個路由實例express.Router()并把這些實例都集成到Node應用中。例如,可以在Node應用中針對不同功能需求創建不同的路由:一個基礎路由,一個用于權限校驗的路由和其他API路由。如此一來,Node應用變得更加模塊化更容易擴展。

創建路由中間件Router.use()

路由中間件實際是一種允許一個request請求被處理之前進行某些操作的機制。例如,在把一個request請求的響應數據返回給用戶之前,我們可以檢查用戶是否有權限,可以記錄日志等等。
下面我們實現一個打印日志的中間件,每次有一個request請求,我們就在console打印一條信息。

// server.js

...

// 獲取router實例
var router = express.Router();

// 路由中間件:每當有一個request請求都會執行
router.use(function(req, res, next) {

  // 打印request的method和url
  console.log(req.method, req.url);

  // 繼續處理request請求,尋找匹配的路由
  next(); 
});

// home頁面路由 (http://localhost:8080)
router.get('/', function(req, res) {
  res.send('im the home page!'); 
});

// about頁面路由 (http://localhost:8080/about)
router.get('/about', function(req, res) {
  res.send('im the about page!'); 
});

// 把定義好的路由集成到Node應用中
app.use('/app', router);

...

我們用router.use()用來定義了路由中間件,并且把它應用到所有訪問我們Node應用的請求上。打開瀏覽器訪問http://localhost:8080/app,我們可以看到console打印的信息:im the home page!。

在代碼中,中間件和路由的位置順序非常重要。一個request請求到來時,它們會按照代碼中的先后順序依次執行。這就意味著如果你把中間件寫在某一個路由的后面,路由會攔截這個request請求并完成響應,中間件則永遠不會被執行。

帶參數的路由 /hello/:name

我們想要在URL中傳遞一個人的名字name,讓NODE應用輸出 Hello name! 這里可以使用帶參數的路由。

// server.js
...
// 獲取router實例
var router = express.Router();
...

// 帶參數的路由 (http://localhost:8080/hello/:name)
router.get('/hello/:name', function(req, res) {
  res.send('hello ' + req.params.name + '!');
});

// 把定義好的路由集成到Node應用中
app.use('/', router);
...

現在我們訪問http://localhost:8080/hello/holly就可以看到瀏覽器頁面展示的信息:

Hello holly!

創建參數中間件

如果想要校驗上面傳入URL的人的名字,確保名字是符合規范的,我們需要在路由中間件中去校驗URL中的參數name。它有個特殊的名字,參數中間件。我們可以使用express.param()去創建它。

// server.js
...

// 獲取router實例
var router = express.Router();

...

// 參數中間件 校驗name參數
router.param('name', function(req, res, next, name) {
  // 在這里進行校驗操作
  console.log('doing name validations on ' + name);

  // 校驗通過我們把校驗后的名字賦值給req對象
  req.name = name;
  // 繼續處理request請求,尋找匹配的路由
  next(); 
});

// 帶參數的路由 (http://localhost:8080/hello/:name)
router.get('/hello/:name', function(req, res) {
  res.send('hello ' + req.name + '!');
});

// 把定義好的路由集成到Node應用中
app.use('/', router);

現在當我們訪問到/hello/:name路由,我們編寫的參數中間件就會介入并做相應的校驗處理。校驗通過我們把校驗后的名字賦值給req對象,并在相應的.get路由中使用req.name獲取校驗后的名字。打開瀏覽器,訪問http://localhost:8080/hello/sally,我們可以看到瀏覽器展示的信息:

Hello sally!

console控制臺打印出:

doing name validations on sally

如果你使用RESTful API,你甚至可以校驗token是否有效,來判斷用戶是否有權限訪問。

鏈式路由

我們也可以直接在app對象上創建路由。利用app.route()可以針對一個路由定義多個路由處理函數。例如,對/login路由發起get請求,展示登錄界面,同時也可以對/login路由發起post請求,提交登錄表單信息。我們就可以使用app.route來創建這個/login路由。

// ROUTES
// ==============================================

app.route('/login')

  // 展示登錄界面 (GET http://localhost:8080/login)
  .get(function(req, res) {
    res.send('this is the login form');
  })

  // 提交登錄表單 (POST http://localhost:8080/login)
  .post(function(req, res) {
    console.log('processing');
    res.send('processing the login form!');
  });

...

總結

使用Express 4.0中的路由,我們可以更靈活的定義路由:

  • 多次使用express.Router()定義一組路由
  • 使用express.Router()劃分模塊,并用app.use()把他們整合起來
  • 使用路由中間件對request請求進行預處理
  • 使用參數中間.param()件對URL中參數進行校驗
  • 使用app.route()創建鏈式路由

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

长治县| 获嘉县| 望都县| 嘉善县| 启东市| 宁蒗| 孟连| 大姚县| 扶绥县| 新沂市| 手游| 长沙县| 新建县| 伊金霍洛旗| 蚌埠市| 交口县| 林州市| 阿鲁科尔沁旗| 西藏| 通化市| 大庆市| 陇南市| 宁都县| 绥宁县| 彩票| 太仆寺旗| 海口市| 谷城县| 西安市| 横山县| 门头沟区| 涡阳县| 上蔡县| 宜丰县| 武宁县| 绩溪县| 静乐县| 那曲县| 陆川县| 沂源县| 临夏市|