摘要:發(fā)送響應(yīng)頭信息參數(shù)用于指定一個(gè)三位的狀態(tài)碼參數(shù)值為一個(gè)字符串,用于指定對(duì)該狀態(tài)碼的描述信息為一個(gè)對(duì)象,用于指定服務(wù)器端創(chuàng)建的響應(yīng)頭對(duì)象用于指定內(nèi)容類型用于將客戶端重定向到另一個(gè)地址用于指定一個(gè)被下載的文件名用于指定服務(wù)器端響應(yīng)內(nèi)容的編
1. 發(fā)送HTTP響應(yīng)頭信息
response.writeHead(statusCode, [reasonPhrase], [headers])
statusCode:參數(shù)用于指定一個(gè)三位的HTTP狀態(tài)碼
reasonPhrase:參數(shù)值為一個(gè)字符串,用于指定對(duì)該狀態(tài)碼的描述信息
headers:為一個(gè)對(duì)象,用于指定服務(wù)器端創(chuàng)建的響應(yīng)頭對(duì)象
content-type:用于指定內(nèi)容類型
location:用于將客戶端重定向到另一個(gè)url地址
content-disposition:用于指定一個(gè)被下載的文件名
content-length:用于指定服務(wù)器端響應(yīng)內(nèi)容的編碼格式
set-cookie:用于在客戶端創(chuàng)建一個(gè)cookie
content-encoding:用于指定服務(wù)器端響應(yīng)內(nèi)容的編碼方式
Cache-Control:用于開啟緩存機(jī)制
Expires:用于指定緩存過期時(shí)間
Etag:用于指定當(dāng)服務(wù)器端響應(yīng)內(nèi)容沒有變化時(shí)不重新下載數(shù)據(jù)
多帶帶設(shè)置響應(yīng)頭信息
可以使用http.ServerResponse對(duì)象的setHeader方法多帶帶設(shè)置響應(yīng)頭信息。
* `response.setHeader(name, value)` * `res.setHeader("Content-Type", "text/type");`
獲取響應(yīng)頭某個(gè)字段的值
response.getHeader(name);
res.getHeader("Content-Type");
刪除一個(gè)響應(yīng)字段
response.removeHeader(name);
res.removeHeader("Content-Type");
檢測(cè)響應(yīng)頭是否已經(jīng)發(fā)送
response.headersSent();
已發(fā)出,為true
未發(fā)送,為false
Date字段
默認(rèn)情況下HTTP服務(wù)器會(huì)自動(dòng)將服務(wù)器端當(dāng)前時(shí)間作為響應(yīng)頭中的Date字段值發(fā)送給客戶端,可以通過將res.sendDate屬性值設(shè)置為false的方法,在響應(yīng)頭中刪除Date字段
res.sendDate = false;
簡(jiǎn)單的HTTP服務(wù)器
const http = require("http"); let server = http.createServer(function (req, res) { if (req.url !== "/favicon.ico") { res.write(""); res.sendDate = false; // 不發(fā)送時(shí)間 if (res.headersSent) { console.log("第一個(gè)響應(yīng)頭已經(jīng)發(fā)送"); } else { console.log("第一個(gè)響應(yīng)頭未發(fā)送"); } res.writeHead(200, {"Content-Type": "text/html"}); if (res.headersSent) { console.log("第二個(gè)響應(yīng)頭已經(jīng)發(fā)送"); } else { console.log("第二個(gè)響應(yīng)頭未發(fā)送"); } res.write("hello, this is http server response content"); } res.end(); }).listen(2596, "localhost", function () { console.log("the http server is running at localhost:3333") });
響應(yīng)數(shù)據(jù)的尾部追加一個(gè)頭信息
res.addTrailers(headers)
const http = require("http"); let server = http.createServer(function (req, res) { if (req.url !== "/favicon.ico") { res.writeHead(200, {"Content-Type": "text/plain", "Trailer": "Content-MD5"}); res.addTrailers({"Content-MD5": "5Q8W9XS5AS98ZX2X5V8V3ZX3ZA8"}); res.write("hello, these are some new massage"); } res.end(); }).listen(3333, "localhost", function () { console.log("the http server is running at localhost:3333") });2. 創(chuàng)建HTTP服務(wù)器
const http = require("http"); const fs = require("fs"); const PORT = 2596; let server = http.createServer((req, res) => { if (req.url !== "/favicon.ico") { let out = fs.createWriteStream("./requestCurl.log"); out.write("客戶端請(qǐng)求的方法為:" + req.method + " "); out.write("客戶端請(qǐng)求的url字符串為:" + req.url + " "); out.write("客戶端請(qǐng)求頭對(duì)象為:" + JSON.stringify(req.headers) + " "); out.write("客戶端請(qǐng)求所用的HTTP版本為:" + req.httpVersion + " "); req.on("data", function (data) { console.log("服務(wù)器端接收到數(shù)據(jù):" + data); }); req.on("end", () => { console.log("客戶端請(qǐng)求數(shù)據(jù)已全部接收完畢"); }) } res.end(); }).listen(PORT, "localhost"); server.on("listening", () => { console.log(`server start listen localhost:${PORT}`); }); server.on("connection", (socket) => { console.log("client and server had been connected"); }); setTimeout(10 * 1000, (socket) => { console.log("server response timeout"); }); server.on("error", (err) => { if (e.code === "EADDRINUSE") { console.log("the port has been used,please change your server port"); } server.on("close", () => { console.log("server closed"); }); }); /*** * 客戶端請(qǐng)求的方法為:GET * 客戶端請(qǐng)求的url字符串為:/ * 客戶端請(qǐng)求頭對(duì)象為:{"user-agent":"curl/7.29.0","host":"localhost:2596","accept":"*|*"} * 客戶端請(qǐng)求所用的HTTP版本為:1.1 * */3. 創(chuàng)建HTTP客戶端
當(dāng)客戶端請(qǐng)求獲取到服務(wù)器響應(yīng)流時(shí),觸發(fā)res.on("data", (chunk) => {})事件
const http = require("http"); let options = { hostname: "www.qq.com", port: 80, path: "/", method: "GET" }; let req = http.request(options, (res) => { console.log(`狀態(tài)碼:${res.statusCode}`); console.log(`響應(yīng)頭:${JSON.stringify(res.headers)}`); res.setEncoding("utf8"); res.on("data", (chunk) => { console.log(`響應(yīng)內(nèi)容:`); }) }); req.on("response", (res) => { console.log(res); // IncomingMessage }); req.on("error", (err) => { if (err.code === "ECONNRESET") { console.log("socket端口超時(shí)"); } else { console.log("在請(qǐng)求數(shù)據(jù)過程中發(fā)生錯(cuò)誤,錯(cuò)誤代碼為:" + err.code) } }); req.end(); /** * 狀態(tài)碼:200 * 響應(yīng)頭:{ * "server": "squid/3.5.24", * "date": "Sun, 25 Feb 2018 14:09:11 GMT", * "content-type": "text/html; charset=GB2312", * "transfer-encoding": "chunked", * "connection": "close", * "vary": "Accept-Encoding, Accept-Encoding, Accept-Encoding, Accept-Encoding", * "expires": "Sun, 25 Feb 2018 14:10:11 GMT", * "cache-control": "max-age=60", * "x-cache": "HIT from shenzhen.qq.com" * } * * **/
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/92888.html
摘要:中各種用于讀取數(shù)據(jù)的對(duì)象對(duì)象描述用于讀取文件代表客戶端請(qǐng)求或服務(wù)器端響應(yīng)代表一個(gè)端口對(duì)象用于創(chuàng)建子進(jìn)程的標(biāo)準(zhǔn)輸出流。如果子進(jìn)程和父進(jìn)程共享輸入輸出流,則子進(jìn)程的標(biāo)準(zhǔn)輸出流被廢棄用于創(chuàng)建子進(jìn)程的標(biāo)準(zhǔn)錯(cuò)誤輸出流。 9. stream流 fs模塊中集中文件讀寫方法的區(qū)別 用途 使用異步方式 使用同步方式 將文件完整讀入緩存區(qū) readFile readFileSync 將文件部...
摘要:將非標(biāo)準(zhǔn)路徑字符串轉(zhuǎn)換為標(biāo)準(zhǔn)路徑字符串解析路徑字符串中的和字符串,返回解析后的標(biāo)準(zhǔn)路徑將多個(gè)斜杠字符串轉(zhuǎn)換為一個(gè)斜杠字符串,例如將轉(zhuǎn)換為將操作系統(tǒng)中的反斜杠字符串轉(zhuǎn)換為正斜杠字符串如果路徑字符串以斜杠字符串結(jié)尾則在轉(zhuǎn)換后的完整路徑字符串末尾 Path 1. normalize()將非標(biāo)準(zhǔn)路徑字符串轉(zhuǎn)換為標(biāo)準(zhǔn)路徑字符串 解析路徑字符串中的..和.字符串,返回解析后的標(biāo)準(zhǔn)路徑 將多個(gè)斜杠...
摘要:域套接字使用或指定請(qǐng)求方法的字符串。請(qǐng)求路徑包含非法字符時(shí)拋出異常。保持資源池周圍的套接字在未來(lái)被用于其它請(qǐng)求。默認(rèn)值為當(dāng)使用的時(shí)候,通過正在保持活動(dòng)的套接字發(fā)送包的頻繁程度。 文章來(lái)源:小青年原創(chuàng)發(fā)布時(shí)間:2016-09-29關(guān)鍵詞:JavaScript,nodejs,http,url ,Query String,爬蟲轉(zhuǎn)載需標(biāo)注本文原始地址: http://zhaomenghuan....
摘要:基本介紹這是一個(gè)基本的環(huán)境搭建不同的操作系統(tǒng)可以選擇不同的安裝方式如果不需要太多的安裝步驟就直接在官網(wǎng)下載最新版安裝包進(jìn)行安裝即可環(huán)境配置必須安裝的軟件更改源與更新系統(tǒng)首先備份下載的源配置文件運(yùn)行生成緩存更新系統(tǒng)安裝使用安裝命 基本介紹 這是一個(gè)基本的Node.js環(huán)境搭建,不同的操作系統(tǒng)可以選擇不同的安裝方式 如果不需要太多的安裝步驟,就直接在Node.js官網(wǎng)下載最新版安裝包進(jìn)行...
閱讀 1098·2021-09-22 15:19
閱讀 1715·2021-08-23 09:46
閱讀 2238·2021-08-09 13:47
閱讀 1416·2019-08-30 15:55
閱讀 1421·2019-08-30 15:55
閱讀 1981·2019-08-30 15:54
閱讀 2809·2019-08-30 15:53
閱讀 719·2019-08-30 11:03