成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

Node.js學(xué)習(xí)之路12——HTTP基本介紹

icyfire / 1798人閱讀

摘要:發(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

相關(guān)文章

  • Node.js學(xué)習(xí)之路08——fs文件系統(tǒng)之stream流的基本介紹

    摘要:中各種用于讀取數(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 將文件部...

    BoYang 評(píng)論0 收藏0
  • Node.js學(xué)習(xí)之路09——Path基本介紹

    摘要:將非標(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è)斜杠...

    zhangke3016 評(píng)論0 收藏0
  • node學(xué)習(xí)之路(一)—— 網(wǎng)絡(luò)請(qǐng)求

    摘要:域套接字使用或指定請(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....

    bovenson 評(píng)論0 收藏0
  • Node.js學(xué)習(xí)之路01——不同操作系統(tǒng)下Node.js環(huán)境搭建

    摘要:基本介紹這是一個(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)行...

    meteor199 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<