Express搭建一個簡單后臺服務(wù)器

Express框架

Web 應(yīng)用程序

Express 是一個保持最小規(guī)模的靈活的 Node.js Web 應(yīng)用程序開發(fā)框架,為 Web 和移動應(yīng)用程序提供一組強大的功能。

API

使用您所選擇的各種 HTTP 實用工具和中間件,快速方便地創(chuàng)建強大的 API。

性能

Express 提供精簡的基本 Web 應(yīng)用程序功能,而不會隱藏您了解和青睞的 Node.js 功能。

Express-路由基本使用

下載:npm install express --save

Hello world

新建一個server.js文件,然后輸入:

const express = require('express');
const app= express();

app.get('/', (req, res)=>{
    req.send('Hello world');
});
app.listen(8083, ()=>{
    console.log('Server is running at http://localhost:8083')
})

然后運行:node server.js
打開:http://localhost:8083/
就出現(xiàn):

11546413582_.pic.jpg

請求和響應(yīng)

Express 應(yīng)用使用回調(diào)函數(shù)的參數(shù): request 和 response 對象來處理請求和響應(yīng)的數(shù)據(jù)。

app.get('/', function (request, response) {
   // --
})

request 和 response 對象的具體介紹:

Request 對象

request 對象表示 HTTP 請求,包含了請求查詢字符串,參數(shù),內(nèi)容,HTTP 頭部等屬性。常見屬性有:

req.app:當(dāng)callback為外部文件時,用req.app訪問express的實例
req.baseUrl:獲取路由當(dāng)前安裝的URL路徑
req.body / req.cookies:獲得「請求主體」/ Cookies
req.fresh / req.stale:判斷請求是否還「新鮮」
req.hostname / req.ip:獲取主機名和IP地址
req.originalUrl:獲取原始請求URL
req.params:獲取路由的parameters
req.path:獲取請求路徑
req.protocol:獲取協(xié)議類型
req.query:獲取URL的查詢參數(shù)串
req.route:獲取當(dāng)前匹配的路由
req.subdomains:獲取子域名
req.accepts():檢查可接受的請求的文檔類型
req.acceptsCharsets / req.acceptsEncodings / req.acceptsLanguages:返回指定字符集的第一個可接受字符編碼
req.get():獲取指定的HTTP請求頭
req.is():判斷請求頭Content-Type的MIME類型

Response 對象

response 對象表示 HTTP 響應(yīng),即在接收到請求時向客戶端發(fā)送的 HTTP 響應(yīng)數(shù)據(jù)。常見屬性有:

res.app:同req.app一樣
res.append():追加指定HTTP頭
res.set()在res.append()后將重置之前設(shè)置的頭
res.cookie(name,value [,option]):設(shè)置Cookie
opition: domain / expires / httpOnly / maxAge / path / secure / signed
res.clearCookie():清除Cookie
res.download():傳送指定路徑的文件
res.get():返回指定的HTTP頭
res.json():傳送JSON響應(yīng)
res.jsonp():傳送JSONP響應(yīng)
res.location():只設(shè)置響應(yīng)的Location HTTP頭,不設(shè)置狀態(tài)碼或者close response
res.redirect():設(shè)置響應(yīng)的Location HTTP頭,并且設(shè)置狀態(tài)碼302
res.render(view,[locals],callback):渲染一個view,同時向callback傳遞渲染后的字符串,如果在渲染過程中有錯誤發(fā)生next(err)將會被自動調(diào)用。callback將會被傳入一個可能發(fā)生的錯誤以及渲染后的頁面,這樣就不會自動輸出了。
res.send():傳送HTTP響應(yīng)
res.sendFile(path [,options] [,fn]):傳送指定路徑的文件 -會自動根據(jù)文件extension設(shè)定Content-Type
res.set():設(shè)置HTTP頭,傳入object可以一次設(shè)置多個頭
res.status():設(shè)置HTTP狀態(tài)碼
res.type():設(shè)置Content-Type的MIME類型

Express-路由

我們已經(jīng)了解了 HTTP 請求的基本應(yīng)用,而路由決定了由誰(指定腳本)去響應(yīng)客戶端請求。
在HTTP請求中,我們可以通過路由提取出請求的URL以及GET/POST參數(shù)。

路由的基本形式:
app.METHOD(PATH, HANDLER)

  1. app 表示的是一個Express的實例
  2. METHOD 是http請求的方法(get, psot..)
  3. PATH 服務(wù)器上的路徑
  4. HANDLER請求之后的執(zhí)行函數(shù)

下面的示例說明了如何定義路由:

// 對/news 頁面進行g(shù)et請求
app.get('news', (req, res)=>{
    res.send('Hello news');
});
// 對/about 頁面進行post請求
app.post('about', (req, res)=>{
    res.send('Hello about');
});
// 對/list* 可匹配 /list+任意字符
app.get('/list*', (req, res)=>{
    res.send('Hello list pages');
})

然后運行:node server.js
打開:http://localhost:8083/

21546417068_.pic.jpg

31546417103_.pic.jpg

41546417120_.pic.jpg

Express-搭建靜態(tài)資源庫

Express 提供了內(nèi)置的中間件 express.static 來設(shè)置靜態(tài)文件如:圖片, CSS, JavaScript 等。

你可以使用 express.static 中間件來設(shè)置靜態(tài)文件路徑。例如,如果你將圖片, CSS, JavaScript 文件放在 public 目錄下,你可以這么寫:
app.use(express.static('public'));

現(xiàn)在,你就可以訪問 public 目錄中的所有文件了:

public/index.html
public/images
public/images/bg.jpeg
public/css
...

如果要使用多個靜態(tài)資源目錄,請多次調(diào)用 express.static 中間件函數(shù):

app.use(express.static('public'))
app.use(express.static('files'))

Express 在靜態(tài)目錄查找文件,因此,存放靜態(tài)文件的目錄名不會出現(xiàn)在 URL 中。
但是您可以給靜態(tài)目錄添加一個路由:
app.use('/static', express.static(path.join(__dirname, 'public')))
設(shè)置/static/public目錄的路由。
現(xiàn)在,你就可以通過帶有 /static 前綴地址來訪問 public 目錄中的文件了。

http://localhost:8083/static/css
http://localhost:8083/static/css/index.css
http://localhost:8083/static/image
http://localhost:8083/static/images/bg.jpeg
http://localhost:8083/static/index.html

為了安全,最好使用絕對路由:
app.use('/static', express.static(path.join(__dirname, 'public')))
然后運行:node server.js
打開:http://localhost:8083/static
就可以訪問public下的所有文件,如圖:

61546420083_.pic_hd.jpg

Express-模板引擎之EJS

EJS 是一套簡單的模板語言,幫你利用普通的 JavaScript 代碼生成 HTML 頁面。

下載Ejs: npm install ejs --save
同目錄下新建myejs.js:

const express= require('express');
const app = express();
//設(shè)置模板文件的目錄,并且新建一個viwes的目錄
app.set('views', './views');
//注冊模板引擎
app.set('view engine', 'ejs');
//使用res.render()來渲染一個視圖并將呈現(xiàn)的HTML字符串發(fā)送給客戶端;
app.get('/', function(req, res,) {
    res.render('index', { title: '測試' });
});
//監(jiān)聽8083端口
app.listen(8083, ()=>{
    console.log('Server is running at http://localhost:8083')
})

在新建views目錄中新建index.ejs:

 <h1><%= title %></h1>

然后運行:node myejs.js
打開:http://localhost:8083
即可看到:

當(dāng)然,也可以返回一個json文件來渲染視圖:
在同目錄下新建一個data.json:

{
    "list": [
    { "name":"小明" , "age":"6", "sex": "男"},
    { "name":"小紅" , "age":"4" ,"sex": "女"},
    { "name":"小亮" , "age":"5" ,"sex": "男"}
    ],
    "source":"神奇二班"
}

然后更改myejs.js:

const express= require('express');
const fs= require('fs');
const app = express();

//設(shè)置模板文件的目錄,并且新建一個viwes的目錄
app.set('views', './views');
//注冊模板引擎
app.set('view engine', 'ejs');
//使用res.render()來渲染一個視圖并將呈現(xiàn)的HTML字符串發(fā)送給客戶端;
app.get('/', function(req, res,) {
    getDataJson((dataJson)=>{
        console.log(dataJson);
        res.render('index', dataJson);
    })
});
//訪問data.json 拿到數(shù)據(jù)解析并返回
const getDataJson=(callBack)=>{
    fs.readFile('./data.json', (err, data)=>{
        if(!err){
            let jsonData= JSON.parse(data);
            callBack(jsonData);
        }else{
            throw err;
        }
    })
}
//監(jiān)聽8083端口
app.listen(8083, ()=>{
    console.log('Server is running at http://localhost:8083')
})

然后更改index.ejs:

<h4><%=source %></h4>
<ul>
    <% for(var i=0; i<list.length; i++){ %>
        <li><%= list[i].name %> | <%= list[i].age %> | <%= list[i].sex %></li>
    <% } %>    
</ul>

然后在運行:
然后運行:node myejs.js
打開:http://localhost:8083

參考:
GitHub源碼
Express官方文檔
EJS 模板引擎

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容