Node.js知識 — HTTP 請求與響應如何設置 Cookie 信息
HTTP Cookie[1] 是服務器發送到用戶瀏覽器并保存在本地的一小塊數據,瀏覽器下次向同一服務器發起請求時會攜帶該 cookie 信息到服務器。
本文來自 “Nodejs技術棧” 一位讀者的一個問題,“Node.js 發起 HTTP 請求時,怎么攜帶上 cookie 信息?”
通常我們在瀏覽器向服務器發起一個請求,瀏覽器會檢查是否有相應的 Cookie(瀏覽器的安裝目錄下有個 cookie 文件夾用來存放各個域下設置的 cookie 信息),如有則自動添加到 Request headers 的 cookie 字段中發送到服務器。
這是瀏覽器的行為會自動幫我們做,那么如果一個 Node.js 做為客戶端呢?
根據 RFC 6265[2] 定義的 cookie 工作方式,在 HTTP 請求處理中,服務端可以在 Response headers 中為客戶端設置 Set-Cookie 字段。另外,客戶端在 HTTP 請求的 Request headers 中以字段 Cookie 的形式將 cookie 信息傳遞給服務端。
下面我們用 Node.js 提供的系統模塊 HTTP[3] 看看如何實現。
這是客戶端的請求方法實現,我們可以在 headers 中直接設置 Cookie 字段,也可通過 http.request 返回的 req 對象調用 setHeader() 方法設置。
- const http = require('http');
- function sendRequest() {
- const req = http.request({
- method: 'GET',
- host: '127.0.0.1',
- port: 3010,
- path: '/api',
- headers: {
- Cookie: ['a=111', 'b=222'] // 方式一設置
- }
- }, res => {
- let data = '';
- res.on('data', chunk => data += chunk.toString());
- res.on('end', () => {
- console.log('response body: ', data);
- console.log('response cookie: ', res.headers['set-cookie']);
- });
- });
- req.setHeader('Cookie', ['b=222', 'c=333']) // 方式二設置
- req.on('error', console.error);
- req.end();
- }
- sendRequest();
服務端代碼如下所示,注意響應設置的是 Set-Cookie 字段。
- const http = require('http');
- http.createServer((req, res) => {
- if (req.url === '/api') {
- console.log('received cookie data: ', req.headers.cookie);
- res.setHeader('Set-Cookie', ['c=333', 'd=444'])
- res.end('Cookie set success!');
- } else {
- res.end('ok!');
- }
- }).listen(3010);
同樣的當你使用 request、node-fetch 等這些 HTTP 的請求庫,其使用是相通的。
參考資料
[1]HTTP Cookie: https://developer.mozilla.org/zh-CN/docs/Web/HTTP/Cookies
[2]RFC 6265: https://tools.ietf.org/html/rfc6265
[3]HTTP: https://nodejs.org/dist/latest-v14.x/docs/api/http.html
本文轉載自微信公眾號「Nodejs技術棧」,可以通過以下二維碼關注。轉載本文請聯系Nodejs技術棧公眾號。