🥸What are express.json() and express.urlencoded()?

https://stackoverflow.com/questions/23259168/what-are-express-json-and-express-urlencoded

I cannot find any documentation on express.json() and express.urlencoded(). What do each of them do exactly?

Đây là lời giải thích có thể giải tỏa những nghi ngờ về express.json()express.urlencoded()cách sử dụng body-parser. Tôi đã mất một thời gian để tìm ra điều này.

  1. Middleware là gì? Đó là những phương thức/hàm/hoạt động được gọi GIỮA quá trình xử lý Yêu cầu và gửi Phản hồi trong phương thức ứng dụng của bạn.

  2. Khi nói đến express.json()express.urlencoded()suy nghĩ cụ thể về các yêu cầu POST (tức là đối tượng yêu cầu .post) và các yêu cầu PUT (tức là đối tượng yêu cầu .put)

  3. Bạn KHÔNG CẦN express.json()express.urlencoded()cho các Yêu cầu GET hoặc Yêu cầu DELETE.

  4. Bạn CẦN express.json()và express.urlencoded()đối với các yêu cầu POST và PUT, vì trong cả hai yêu cầu này, bạn đang gửi dữ liệu (dưới dạng một số đối tượng dữ liệu) đến máy chủ và bạn đang yêu cầu máy chủ chấp nhận hoặc lưu trữ dữ liệu đó (đối tượng), được bao gồm trong phần thân (tức là req.body) của Yêu cầu (POST hoặc PUT) đó

  5. Express cung cấp cho bạn phần mềm trung gian để xử lý dữ liệu (đến) (đối tượng) trong nội dung yêu cầu.

    a. express.json()là một phương thức tích hợp trong express để nhận dạng Request Object đến là JSON Object . Phương thức này được gọi là middleware trong ứng dụng của bạn bằng cách sử dụng mã:app.use(express.json());

    b. express.urlencoded()là một phương thức tích hợp trong express để nhận dạng Request Object đến dưới dạng chuỗi hoặc mảng . Phương thức này được gọi là phần mềm trung gian trong ứng dụng của bạn bằng cách sử dụng mã:app.use(express.urlencoded());

  6. HOẶC LÀ, tôi khuyên bạn nên sử dụng body-parser (đây là một gói NPM) để làm điều tương tự. Nó được phát triển bởi những người đã xây dựng express và được thiết kế để hoạt động với express. body-parser từng là một phần của express. Hãy nghĩ về body-parser dành riêng cho POST Request (tức là đối tượng yêu cầu .post) và/hoặc PUT Request (tức là đối tượng yêu cầu .put).

  7. Trong body-parser bạn có thể làm

// calling body-parser to handle the Request Object from POST requests
var bodyParser = require('body-parser');
// parse application/json, basically parse incoming Request Object as a JSON Object 
app.use(bodyParser.json());
// parse application/x-www-form-urlencoded, basically can only parse incoming Request Object if strings or arrays
app.use(bodyParser.urlencoded({ extended: false }));
// combines the 2 above, then you can parse incoming Request Object if object, with nested objects, or generally any type.
app.use(bodyParser.urlencoded({ extended: true }));

Nếu bạn hỏi tôi "sự khác biệt giữa express.urlencoded({extended: false})express.json()" là gì, thì sự khác biệt là:

<form action="/" method="POST">
    <input type="text" name="username">
    <button>Submit</button>
</form>

Ví dụ, nếu bạn điền "dean" vào biểu mẫu rồi gửi đi, Express sẽ không biết nội dung bên trong có mã Express này là gì:

const express = require('express')
const app = express()
app.use(express.json())
// app.use(express.urlencoded({ extended: false }))
app.use(express.static("public"))
app.get("/", (req, res) => {
    res.sendFile("index.html")
})
app.post("/", (req, res) => {
    res.send(req.body)
})
const port = process.env.PORT || 3001
app.listen(port, () => {
    console.log(`Server Up in Port ${port}`);
})

Nó sẽ được gửi {}sau khi bạn nhấp vào gửi. Nhưng nếu bạn bỏ bình luận app.use(express.urlencoded({extended: false})), thì bạn sẽ nhận được {"username": "dean"}.

Vì vậy, sự khác biệt là express.json()một trình phân tích cú pháp nội dung cho yêu cầu đăng bài ngoại trừ biểu mẫu đăng bài html và express.urlencoded({extended: false})là một trình phân tích cú pháp nội dung cho biểu mẫu đăng bài html.

Cả phần mềm trung gian jsonurlencodedphần mềm trung gian đều là một phần của bodyParser . Đây là nội dung của README:

bodyParser([tùy chọn])

Trả về phần mềm trung gian phân tích cả jsonurlencoded. optionsĐược chuyển đến cả hai phần mềm trung gian.

bodyParser.json([tùy chọn])

Trả về phần mềm trung gian chỉ phân tích cú pháp json. Các tùy chọn là:

  • strict - chỉ phân tích các đối tượng và mảng

  • limit<1mb> - kích thước yêu cầu tối đa

  • reviver- đã chuyển đếnJSON.parse()

bodyParser.urlencoded([tùy chọn])

Trả về phần mềm trung gian chỉ phân tích cú pháp urlencodedvới mô-đun qs . Các tùy chọn là:

  • limit<1mb> - kích thước yêu cầu tối đa

Chỉ cần nhớ rằng bodyParser.urlencoded với tùy chọn extended = false sẽ sử dụng chuỗi truy vấn thư viện ví dụ: bodypParser.urlencoded({ extended: false }) //querystring và thư viện qs nếu tùy chọn mở rộng được đặt thành true ví dụ: bodypParser.urlencoded({ extended: true })

Hiện nay expressJS đã có một số phần mềm trung gian giúp nhà phát triển thực hiện một số nhiệm vụ tẻ nhạt, như chuyển đổi nội dung yêu cầu sang JSON và nhiều nhiệm vụ khác.

Ví dụ về các phần mềm trung gian ExpressJS tích hợp này là

  • express.json()

  • express.urlencoded()

express.json() là một phần mềm trung gian express được xây dựng để chuyển đổi nội dung yêu cầu thành JSON.

express.urlencoded() giống như express.json() chuyển đổi nội dung yêu cầu thành JSON, nó cũng thực hiện một số chức năng khác như: chuyển đổi dữ liệu biểu mẫu thành JSON, v.v.

Phần mềm trung gian này có sẵn trong Express v4.16.0 trở lên

app.use(express.urlencoded({ extended: true}))

Phần mềm trung gian này có sẵn trong Express v4.16.0 trở lên.

app.use(express.urlencoded({ extended: true}))

extended[boolean]: Tùy chọn này cho phép chọn giữa việc phân tích cú pháp dữ liệu được mã hóa URL bằng thư viện chuỗi truy vấn (khi sai) hoặc thư viện qs (khi đúng). Cú pháp "extended" cho phép mã hóa các đối tượng và mảng phong phú thành định dạng được mã hóa URL, cho phép trải nghiệm giống như JSON với URL được mã hóa

Last updated