了解如何使用 Node 通過 HTTP 請求體提取發送的 JSON 數據。
這是如何提取請求體中作為 JSON 發送的數據。
如果你使用的是 Express,那就非常簡單:使用 body-parser
Node 模塊。
例如,要獲取此請求的請求體:
const axios = require('axios')
axios.post('/todos', {
todo: '購買牛奶',
})
這是對應的服務器端代碼:
const bodyParser = require('body-parser')
app.use(
bodyParser.urlencoded({
extended: true,
})
)
app.use(bodyParser.json())
app.post('/endpoint', (req, res) => {
console.log(req.body.todo)
})
如果你沒有使用 Express,而是想在原生的 Node 中實現這個功能,當然需要更多的工作,因為 Express 為你抽象了很多內容。
關鍵的是,當你使用 http.createServer()
初始化 HTTP 服務器時,回調函數被調用時,服務器已經獲取了所有的 HTTP 標頭,但是沒有請求體。
在連接的回調中,傳遞的 request
對象是一個流。
因此,我們需要監聽請求體內容被處理的事件,並且它以塊的形式進行處理。
我們首先通過監聽流的 data
事件來獲取數據,在數據結束時,流的 end
事件被調用一次:
const server = http.createServer((req, res) => {
// 我們可以訪問 HTTP 標頭
req.on('data', (chunk) => {
console.log(`數據塊可用:${chunk}`)
})
req.on('end', () => {
// 數據結束
})
})
因此,為了訪問數據,假設我們預期接收到的是字符串,我們必須將其放入數組中:
const server = http.createServer((req, res) => {
let data = []
req.on('data', (chunk) => {
data.push(chunk)
})
req.on('end', () => {
JSON.parse(data).todo // '購買牛奶'
})
})