欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

使用Express處理請求和托管靜態(tài)資源方式

 更新時(shí)間:2022年09月06日 10:06:17   作者:Blizzard前端  
這篇文章主要介紹了使用Express處理請求和托管靜態(tài)資源方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

Express

Express時(shí)基于Node.js平臺,快速、開放、極簡的Web開發(fā)框架。

通俗的理解:

Express的作用和Node.js內(nèi)置的http模塊類似,是專門用來創(chuàng)建Web服務(wù)器的。

Express的本質(zhì):

就是一個(gè)npm上的第三方包,提供了快速創(chuàng)建Web服務(wù)器的便捷方法

點(diǎn)擊前往 Express–Node.js Web應(yīng)用程序框架

Express對比Http模塊

http內(nèi)置模塊用起來很復(fù)雜,開發(fā)效率低。Express是基于內(nèi)置的http模塊進(jìn)一部封裝出來的,能夠極大的提高開發(fā)效率。

Express的主要作用

對于前端程序員來說,最常見的兩種服務(wù)器,分別是:

1.Web網(wǎng)站服務(wù)器:專門對外提供Web網(wǎng)頁資源的服務(wù)器

2.API接口服務(wù)器:專門對外提供API接口的服務(wù)器

使用Express,我們可以方便、快速的創(chuàng)建Web網(wǎng)站的服務(wù)器或API接口的服務(wù)器

Express安裝

npm i express

創(chuàng)建Web服務(wù)器:

// 1. 導(dǎo)入 express
const express = require('express')
// 2. 創(chuàng)建 web 服務(wù)器
const app = express()


// 4. 監(jiān)聽客戶端的 GET 和 POST 請求,并向客戶端響應(yīng)具體的內(nèi)容
// req:請求對象(包含了與請求相關(guān)的屬性與方法)
// res:響應(yīng)對象(包含了與響應(yīng)有關(guān)的屬性和方法)
app.get('/user', (req, res) => {
? // 調(diào)用 express 提供的 res.send() 方法,向客戶端響應(yīng)一個(gè) JSON 對象
? res.send({ name: 'zs', age: 20, gender: '男' })
})
app.post('/user', (req, res) => {
? // 調(diào)用 express 提供的 res.send() 方法,向客戶端響應(yīng)一個(gè) 文本字符串
? res.send('請求成功')
})
app.get('/', (req, res) => {
? // 通過 req.query 可以獲取到客戶端發(fā)送過來的 查詢參數(shù)
? // 注意:默認(rèn)情況下,req.query 是一個(gè)空對象
? console.log(req.query)
? res.send(req.query)
})
// 注意:這里的 :id 是一個(gè)動態(tài)的參數(shù)
app.get('/user/:ids/:username', (req, res) => {
? // req.params 是動態(tài)匹配到的 URL 參數(shù),默認(rèn)也是一個(gè)空對象
? console.log(req.params)
? res.send(req.params)
})

// 3. 啟動 web 服務(wù)器
app.listen(80, () => {
? console.log('express server running at http://127.0.0.1')
})

Express靜態(tài)資源處理

express.static()

express提供了一個(gè)非常好用的函數(shù),叫做express.static()通過它,我們可以非常方便地創(chuàng)建一個(gè)靜態(tài)資源服務(wù)器

例如,通過如下代碼就可以將public目錄下的圖片、CSS文件、JavaScript文件對外開放訪問了:

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

可以訪問如下public目錄中的所有文件了(在瀏覽器通過本地ip訪問):

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

// 在這里,調(diào)用 express.static() 方法,快速的對外提供靜態(tài)資源
app.use('/files', express.static('./files'))
app.use(express.static('./clock'))
//當(dāng)相對路徑報(bào)錯(cuò)的時(shí)候,換成絕對路徑即可
//app.use(express.static(path.join(__dirname, './clock')))

app.listen(80, () => {
? console.log('express server running at http://127.0.0.1')
})

注意:Express在指定的靜態(tài)目錄下查找文件,并對外提供資源的訪問路徑。因此,存放靜態(tài)文件的目錄名不會出現(xiàn)在URL中

托管多個(gè)靜態(tài)資源目錄

如果想要托管多個(gè)靜態(tài)資源目錄,請多次調(diào)用express.static()函數(shù)

app.use('/files', express.static('./files'))
app.use(express.static('./clock'))

訪問靜態(tài)資源文件時(shí),express.static()函數(shù)會根據(jù)目錄的添加順序查找所需要的文件

掛載路徑前綴

如果希望在托管的靜態(tài)資源訪問路徑之前,掛載路徑前綴,則可以使用如下的方式

app.use('/public', express.static('public'))

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論