圖解HTTP筆記

第一章

TCP/IP工作流 ![屏幕快照 2016-11-28 上午12.10.08.png](http://upload-images.jianshu.io/upload_images/1613338-bb6f6a8d44e1a192.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

IP協(xié)議

ip協(xié)議里重要的是IP地址和MAC地址

使用 ARP 協(xié)議憑借 MAC 地址進(jìn)行通信

“(Address Resolution Protocol)。ARP 是一種用以解析地址的協(xié)議愈涩,根據(jù)通信方的 IP 地址就可以反查出對(duì)應(yīng)的 MAC 地址焚廊。”


屏幕快照 2016-11-28 上午12.15.06.png

TCP

“按層次分荧缘,TCP 位于傳輸層,提供可靠的字節(jié)流服務(wù)。

所謂的字節(jié)流服務(wù)(Byte Stream Service)是指推溃,為了方便傳輸,將大塊數(shù)據(jù)分割成以報(bào)文段(segment)為單位的數(shù)據(jù)包進(jìn)行管理届腐。而可靠的傳輸服務(wù)是指铁坎,能夠把數(shù)據(jù)準(zhǔn)確可靠地傳給對(duì)方”

DNS(Domain Name System)

“DNS(Domain Name System)服務(wù)是和 HTTP 協(xié)議一樣位于應(yīng)用層的協(xié)議。它提供域名到 IP 地址之間的解析服務(wù)犁苏∮财迹”


屏幕快照 2016-11-28 上午12.21.26.png
TCP IP DNS合作流程

URI 和 URL

URL(Uniform Resource Locator)是URI(Uniform Resource Identifier)的子集

URI 格式

屏幕快照 2016-11-28 上午12.29.37.png

“第 2 章 簡(jiǎn)單的 HTTP 協(xié)議”

請(qǐng)求
響應(yīng)

http為無(wú)狀態(tài)協(xié)議

“HTTP 是一種不保存狀態(tài),即無(wú)狀態(tài)(stateless)協(xié)議围详。HTTP 協(xié)議自身不對(duì)請(qǐng)求和響應(yīng)之間的通信狀態(tài)進(jìn)行保存朴乖。也就是說(shuō)在 HTTP 這個(gè)級(jí)別祖屏,協(xié)議對(duì)于發(fā)送過(guò)的請(qǐng)求或響應(yīng)都不做持久化處理÷蛐撸”

持久連接

屏幕快照 2016-11-29 上午12.38.56.png

管線(xiàn)化袁勺,并發(fā)請(qǐng)求

屏幕快照 2016-11-29 上午12.38.25.png

“第 3 章 HTTP 報(bào)文內(nèi)的 ”

“HTTP 報(bào)文本身是由多行(用 CR+LF 作換行符)數(shù)據(jù)構(gòu)成的字符串文本⌒笃眨”

“HTTP 報(bào)文大致可分為報(bào)文首部和報(bào)文主體兩塊期丰。兩者由最初出現(xiàn)的空行(CR+LF)來(lái)劃分。通常漠嵌,并不一定要有報(bào)文主體咐汞。”

屏幕快照 2016-11-29 上午12.43.17.png
屏幕快照 2016-11-29 上午12.50.14.png
  • 報(bào)文(message)

是 HTTP 通信中的基本單位儒鹿,由 8 位組字節(jié)流(octet sequence化撕,其中 octet 為 8 個(gè)比特)組成,通過(guò) HTTP 通信傳輸约炎。

  • 實(shí)體(entity)

作為請(qǐng)求或響應(yīng)的有效載荷數(shù)據(jù)(補(bǔ)充項(xiàng))被傳輸植阴,其內(nèi)容由實(shí)體首部和實(shí)體主體組成』常”

HTTP 報(bào)文的主體用于傳輸請(qǐng)求或響應(yīng)的實(shí)體主體掠手。

通常,報(bào)文主體等于實(shí)體主體狸捕。只有當(dāng)傳輸中進(jìn)行編碼操作時(shí)喷鸽,實(shí)體主體的內(nèi)容發(fā)生變化,才導(dǎo)致它和報(bào)文主體產(chǎn)生差異灸拍。

發(fā)送多種數(shù)據(jù)的多部分對(duì)象集合

  • multipart/form-data

在 Web 表單文件上傳時(shí)使用做祝。

  • multipart/byteranges

狀態(tài)碼 206(Partial Content,部分內(nèi)容)響應(yīng)報(bào)文包含了多個(gè)范圍的內(nèi)容時(shí)使用鸡岗。

  • multipart/form-data
“Content-Type: multipart/form-data; boundary=AaB03x
 
--AaB03x
Content-Disposition: form-data; name="field1"
 
Joe Blow
--AaB03x
Content-Disposition: form-data; name="pics"; filename="file1.txt"
Content-Type: text/plain
 
...(file1.txt的數(shù)據(jù))...”

摘錄來(lái)自: 上野宣混槐、于均良. “圖解HTTP”。 iBooks. 
  • multipart/byteranges
HTTP/1.1 206 Partial Content
Date: Fri, 13 Jul 2012 02:45:26 GMT
Last-Modified: Fri, 31 Aug 2007 02:02:20 GMT
Content-Type: multipart/byteranges; boundary=THIS_STRING_SEPARATES


--THIS_STRING_SEPARATES
Content-Type: application/pdf
Content-Range: bytes 500-999/8000


...(范圍指定的數(shù)據(jù))...
--THIS_STRING_SEPARATES
Content-Type: application/pdf
Content-Range: bytes 7000-7999/8000


...(范圍指定的數(shù)據(jù))...
--THIS_STRING_SEPARATES--

使用 boundary 字符串來(lái)劃分多部分對(duì)象集合指明的各類(lèi)實(shí)體轩性。在 boundary 字符串指定的各個(gè)實(shí)體的起始行之前插入“--”標(biāo)記(例如:--AaB03x声登、--THIS_STRING_SEPARATES),而在多部分對(duì)象集合對(duì)應(yīng)的字符串的最后插入“--”標(biāo)記(例如:--AaB03x--揣苏、--THIS_STRING_SEPARATES--)作為結(jié)束悯嗓。

“第 4 章 返回結(jié)果的 HTTP 狀態(tài)碼”

屏幕快照 2016-11-30 上午1.08.29.png

2XX

  • 200 OK
  • 204 No Content
  • 206 Part Content

3XX 重定向

  • 301 Moved Permanently
    永久性重定向。該狀態(tài)碼表示請(qǐng)求的資源已被分配了新的 URI舒岸,以后應(yīng)使用資源現(xiàn)在所指的 URI

  • 302 Found
    臨時(shí)性重定向.該狀態(tài)碼表示請(qǐng)求的資源已被分配了新的 URI绅作,希望用戶(hù)(本次)能使用新的 URI 訪(fǎng)問(wèn)。

和 301 Moved Permanently 狀態(tài)碼相似蛾派,但 302 狀態(tài)碼代表的資源不是被永久移動(dòng)俄认,只是臨時(shí)性質(zhì)的个少。換句話(huà)說(shuō),已移動(dòng)的資源對(duì)應(yīng)的 URI 將來(lái)還有可能發(fā)生改變眯杏。

  • 303 See Other
    該狀態(tài)碼表示由于請(qǐng)求對(duì)應(yīng)的資源存在著另一個(gè) URI夜焦,應(yīng)使用 GET 方法定向獲取請(qǐng)求的資源。

當(dāng) 301岂贩、302茫经、303 響應(yīng)狀態(tài)碼返回時(shí),幾乎所有的瀏覽器都會(huì)把 POST 改成 GET萎津,并刪除請(qǐng)求報(bào)文內(nèi)的主體卸伞,之后請(qǐng)求會(huì)自動(dòng)再次發(fā)送。
301锉屈、302 標(biāo)準(zhǔn)是禁止將 POST 方法改變成 GET 方法的荤傲,但實(shí)際使用時(shí)大家都會(huì)這么做。

4XX 客戶(hù)端錯(cuò)誤

  • 400 Bad Request
    該狀態(tài)碼表示請(qǐng)求報(bào)文中存在語(yǔ)法錯(cuò)誤颈渊。當(dāng)錯(cuò)誤發(fā)生時(shí)遂黍,需修改請(qǐng)求的內(nèi)容后再次發(fā)送請(qǐng)求。另外俊嗽,瀏覽器會(huì)像 200 OK 一樣對(duì)待該狀態(tài)碼雾家。

  • 401 Unauthorized
    該狀態(tài)碼表示發(fā)送的請(qǐng)求需要有通過(guò) HTTP 認(rèn)證(BASIC 認(rèn)證、DIGEST 認(rèn)證)的認(rèn)證信息绍豁。另外若之前已進(jìn)行過(guò) 1 次請(qǐng)求芯咧,則表示用 戶(hù)認(rèn)證失敗。
    返回含有 401 的響應(yīng)必須包含一個(gè)適用于被請(qǐng)求資源的
    WWW-Authenticate 首部用以質(zhì)詢(xún)(challenge)用戶(hù)信息竹揍。當(dāng)瀏覽器初次接收到 401 響應(yīng)唬党,會(huì)彈出認(rèn)證用的對(duì)話(huà)窗口。

  • 403 Forbidden
    該狀態(tài)碼表明對(duì)請(qǐng)求資源的訪(fǎng)問(wèn)被服務(wù)器拒絕了鬼佣。服務(wù)器端沒(méi)有必要給出拒絕的詳細(xì)理由,但如果想作說(shuō)明的話(huà)霜浴,可以在實(shí)體的主體部分對(duì)原因進(jìn)行描述晶衷,這樣就能讓用戶(hù)看到了。

  • 404 Not Found
    該狀態(tài)碼表明服務(wù)器上無(wú)法找到請(qǐng)求的資源阴孟。除此之外晌纫,也可以在服務(wù)器端拒絕請(qǐng)求且不想說(shuō)明理由時(shí)使用。

5XX 服務(wù)器錯(cuò)誤

  • 500 Internal Server Error
    該狀態(tài)碼表明服務(wù)器端在執(zhí)行請(qǐng)求時(shí)發(fā)生了錯(cuò)誤永丝。也有可能是 Web 應(yīng)用存在的 bug 或某些臨時(shí)的故障锹漱。

  • 503 Service Unavailable
    該狀態(tài)碼表明服務(wù)器暫時(shí)處于超負(fù)載或正在進(jìn)行停機(jī)維護(hù),現(xiàn)在無(wú)法處理請(qǐng)求慕嚷。如果事先得知解除以上狀況需要的時(shí)間哥牍,最好寫(xiě)入 RetryAfter 首部字段再返回給客戶(hù)端毕泌。

狀態(tài)碼和狀況的不一致
不少返回的狀態(tài)碼響應(yīng)都是錯(cuò)誤的,但是用戶(hù)可能察覺(jué)不到這點(diǎn)嗅辣。比如 Web 應(yīng)用程序內(nèi)部發(fā)生錯(cuò)誤撼泛,狀態(tài)碼依然返回 200 OK,這種情況也經(jīng)常遇到澡谭。

第 5 章 與 HTTP 協(xié)作的 Web 服務(wù)器

用單臺(tái)虛擬主機(jī)實(shí)現(xiàn)多個(gè)域名



通信數(shù)據(jù)轉(zhuǎn)發(fā)程序 :代理愿题、網(wǎng)關(guān)、隧道

代理

代理服務(wù)器的基本行為就是接收客戶(hù)端發(fā)送的請(qǐng)求后轉(zhuǎn)發(fā)給其他服務(wù)器蛙奖。代理不改變請(qǐng)求 URI潘酗,會(huì)直接發(fā)送給前方持有資源的目標(biāo)服務(wù)器。

Paste_Image.png
Paste_Image.png
  • 緩存代理

  • 透明代理 不對(duì)報(bào)文加工

  • 非透明代理 對(duì)報(bào)文加工

網(wǎng)關(guān)

Paste_Image.png

保存資源的緩存

緩存是指代理服務(wù)器或客戶(hù)端本地磁盤(pán)內(nèi)保存的資源副本雁仲。利用緩存可減少對(duì)源服務(wù)器的訪(fǎng)問(wèn)仔夺,因此也就節(jié)省了通信流量和通信時(shí)間。

第 6 章 HTTP 首部

HTTP 報(bào)文首部

Paste_Image.png

請(qǐng)求報(bào)文

Paste_Image.png

響應(yīng)報(bào)文

Paste_Image.png
響應(yīng)報(bào)文示例

HTTP 首部字段

使用首部字段是為了給瀏覽器和服務(wù)器提供報(bào)文主體大小伯顶、所使用的語(yǔ)言囚灼、認(rèn)證信息等內(nèi)容。

4 種 HTTP 首部字段類(lèi)型

HTTP 首部字段根據(jù)實(shí)際用途被分為以下 4 種類(lèi)型祭衩。

  • 通用首部字段(General Header Fields)

請(qǐng)求報(bào)文和響應(yīng)報(bào)文兩方都會(huì)使用的首部灶体。

Paste_Image.png
  • 請(qǐng)求首部字段(Request Header Fields)

從客戶(hù)端向服務(wù)器端發(fā)送請(qǐng)求報(bào)文時(shí)使用的首部。補(bǔ)充了請(qǐng)求的附加內(nèi)容掐暮、客戶(hù)端信息蝎抽、響應(yīng)內(nèi)容相關(guān)優(yōu)先級(jí)等信息。

Paste_Image.png

Accept

Paste_Image.png

文本文件
text/html, text/plain, text/css ...
application/xhtml+xml, application/xml ...
圖片文件
image/jpeg, image/gif, image/png ...
視頻文件
video/mpeg, video/quicktime ...
應(yīng)用程序使用的二進(jìn)制文件
application/octet-stream, application/zip ..

若想要給顯示的媒體類(lèi)型增加優(yōu)先級(jí)路克,則使用 q= 來(lái)額外表示權(quán)重值 1樟结,用分號(hào)(;)進(jìn)行分隔。權(quán)重值 q 的范圍是 0~1(可精確到小數(shù)點(diǎn)后 3 位)精算,且 1 為最大值瓢宦。不指定權(quán)重 q 值時(shí),默認(rèn)權(quán)重為 q=1.0灰羽。

Accept-Encoding

Paste_Image.png
編碼例子

Authorization

Paste_Image.png

Host

虛擬主機(jī)運(yùn)行在同一個(gè) IP 上驮履,因此使用首部字段 Host 加以區(qū)分

首部字段 Host 和以單臺(tái)服務(wù)器分配多個(gè)域名的虛擬主機(jī)的工作機(jī)制有很密切的關(guān)聯(lián),這是首部字段 Host 必須存在的意義廉嚼。

If-match

Paste_Image.png
Paste_Image.png

If-Modified-Since

Paste_Image.png

If-None-Match

Paste_Image.png

在 GET 或 HEAD 方法中使用首部字段 If-None-Match 可獲取最新的資源玫镐。因此,這與使用首部字段 If-Modified-Since 時(shí)有些類(lèi)似怠噪。

If-Range

Paste_Image.png

If-Unmodified-Since

首部字段 If-Unmodified-Since 和首部字段 If-Modified-Since 的作用相反恐似。

Max-Forwards

Paste_Image.png

防止無(wú)限轉(zhuǎn)發(fā),也可以

Referer

Paste_Image.png

因?yàn)樵假Y源的 URI 中的查詢(xún)字符串可能含有 ID 和密碼等保密信息傍念,要是寫(xiě)進(jìn) Referer 轉(zhuǎn)發(fā)給其他服務(wù)器矫夷,則有可能導(dǎo)致保密信息的泄露葛闷。

TE

首部字段 TE 會(huì)告知服務(wù)器客戶(hù)端能夠處理響應(yīng)的傳輸編碼方式及相對(duì)優(yōu)先級(jí)。它和首部字段 Accept-Encoding 的功能很相像口四,但是用于傳輸編碼
首部字段 TE 除指定傳輸編碼之外孵运,還可以指定伴隨 trailer 字段的分塊傳輸編碼的方式。應(yīng)用后者時(shí)蔓彩,只需把 trailers 賦值給該字段值治笨。

  • 響應(yīng)首部字段(Response Header Fields)

從服務(wù)器端向客戶(hù)端返回響應(yīng)報(bào)文時(shí)使用的首部。補(bǔ)充了響應(yīng)的附加內(nèi)容赤嚼,也會(huì)要求客戶(hù)端附加額外的內(nèi)容信息旷赖。

Accept-Ranges

Age

ETag

Proxy-Authenticate

Location

Paste_Image.png

Proxy-Authenticate

Retry-After

Paste_Image.png

Server

Vary

Paste_Image.png

WWW-Authenticate

  • 實(shí)體首部字段(Entity Header Fields)

針對(duì)請(qǐng)求報(bào)文和響應(yīng)報(bào)文的實(shí)體部分使用的首部。補(bǔ)充了資源內(nèi)容更新時(shí)間等與實(shí)體有關(guān)的信息更卒。

Paste_Image.png
Paste_Image.png

Allow

首部字段 Allow 用于通知客戶(hù)端能夠支持 Request-URI 指定資源的所有 HTTP 方法等孵。當(dāng)服務(wù)器接收到不支持的 HTTP 方法時(shí),會(huì)以狀態(tài)碼 405 Method Not Allowed 作為響應(yīng)返回蹂空。與此同時(shí)俯萌,還會(huì)把所有能支持的 HTTP 方法寫(xiě)入首部字段 Allow 后返回。

Content-Encoding

首部字段 Content-Encoding 會(huì)告知客戶(hù)端服務(wù)器對(duì)實(shí)體的主體部分選用的內(nèi)容編碼方式上枕。內(nèi)容編碼是指在不丟失實(shí)體信息的前提下所進(jìn)行的壓縮咐熙。

  • gzip

  • compress

  • deflate

  • identity

Content-Language

Content-Length

首部字段 Content-Length 表明了實(shí)體主體部分的大小(單位是字節(jié))辨萍。對(duì)實(shí)體主體進(jìn)行內(nèi)容編碼傳輸時(shí)棋恼,不能再使用 Content-Length 首部字段。由于實(shí)體主體大小的計(jì)算方法略微復(fù)雜锈玉,所以在此不再展開(kāi)爪飘。讀者若想一探究竟,可參考 RFC2616 的 4.4拉背。

Content-MD5

Paste_Image.png

Content-Range

Paste_Image.png

Content-Type

Expire

Paste_Image.png

源服務(wù)器不希望緩存服務(wù)器對(duì)資源緩存時(shí)师崎,最好在 Expires 字段內(nèi)寫(xiě)入與首部字段 Date 相同的時(shí)間值。

但是椅棺,當(dāng)首部字段 Cache-Control 有指定 max-age 指令時(shí)抡诞,比起首部字段 Expires,會(huì)優(yōu)先處理 max-age 指令土陪。

Last-Modified

Paste_Image.png
  • 為 Cookie 服務(wù)的首部字段
Paste_Image.png

![Upload Paste_Image.png failed. Please try again.]

Paste_Image.png

第 7 章 確保 Web 安全的 HTTPS

HTTP+ 加密 + 認(rèn)證 + 完整性保護(hù) =HTTPS

HTTPS 并非是應(yīng)用層的一種新協(xié)議。只是 HTTP 通信接口部分用 SSL(Secure Socket Layer)和 TLS(Transport Layer Security)協(xié)議代替而已肴熏。

通常鬼雀,HTTP 直接和 TCP 通信。當(dāng)使用 SSL 時(shí)蛙吏,則演變成先和 SSL 通信源哩,再由 SSL 和 TCP 通信了鞋吉。簡(jiǎn)言之,所謂 HTTPS励烦,其實(shí)就是身披 SSL 協(xié)議這層外殼的 HTTP谓着。

Paste_Image.png
公開(kāi)密鑰

HTTPS 采用混合加密機(jī)制

HTTPS 采用共享密鑰加密和公開(kāi)密鑰加密兩者并用的混合加密機(jī)制。若密鑰能夠?qū)崿F(xiàn)安全交換坛掠,那么有可能會(huì)考慮僅使用公開(kāi)密鑰加密來(lái)通信赊锚。但是公開(kāi)密鑰加密與共享密鑰加密相比,其處理速度要慢屉栓。
所以應(yīng)充分利用兩者各自的優(yōu)勢(shì)舷蒲,將多種方法組合起來(lái)用于通信。在交換密鑰環(huán)節(jié)使用公開(kāi)密鑰加密方式友多,之后的建立通信交換報(bào)文階段則使用共享密鑰加密方式牲平。

Paste_Image.png
Paste_Image.png

第 8 章 確認(rèn)訪(fǎng)問(wèn)用戶(hù)身份的認(rèn)證

HTTP 使用的認(rèn)證方式

  • HTTP/1.1 使用的認(rèn)證方式如下所示。

  • BASIC 認(rèn)證(基本認(rèn)證)

Paste_Image.png
  • DIGEST 認(rèn)證(摘要認(rèn)證)

  • SSL 客戶(hù)端認(rèn)證

  • FormBase 認(rèn)證(基于表單認(rèn)證)

Session 管理及 Cookie 應(yīng)用

一般會(huì)使用 Cookie 來(lái)管理 Session(會(huì)話(huà))域滥。

基于表單認(rèn)證本身是通過(guò)服務(wù)器端的 Web 應(yīng)用纵柿,將客戶(hù)端發(fā)送過(guò)來(lái)的用戶(hù) ID 和密碼與之前登錄過(guò)的信息做匹配來(lái)進(jìn)行認(rèn)證的。

但鑒于 HTTP 是無(wú)狀態(tài)協(xié)議启绰,之前已認(rèn)證成功的用戶(hù)狀態(tài)無(wú)法通過(guò)協(xié)議層面保存下來(lái)昂儒。即,無(wú)法實(shí)現(xiàn)狀態(tài)管理酬土,因此即使當(dāng)該用戶(hù)下一次繼續(xù)訪(fǎng)問(wèn)荆忍,也無(wú)法區(qū)分他與其他的用戶(hù)。于是我們會(huì)使用 Cookie 來(lái)管理 Session撤缴,以彌補(bǔ) HTTP 協(xié)議中不存在的狀態(tài)管理功能刹枉。

Paste_Image.png

如果 Session ID 被第三方盜走,對(duì)方就可以偽裝成你的身份進(jìn)行惡意操作了屈呕。因此必須防止 Session ID 被盜微宝,或被猜出。為了做到這點(diǎn)虎眨,Session ID 應(yīng)使用難以推測(cè)的字符串蟋软,且服務(wù)器端也需要進(jìn)行有效期的管理,保證其安全性嗽桩。

另外岳守,為減輕跨站腳本攻擊(XSS)造成的損失,建議事先在 Cookie 內(nèi)加上 httponly 屬性碌冶。

使用瀏覽器進(jìn)行全雙工通信的 WebSocket

WebSocket湿痢,即 Web 瀏覽器與 Web 服務(wù)器之間全雙工通信標(biāo)準(zhǔn)。其中,WebSocket 協(xié)議由 IETF 定為標(biāo)準(zhǔn)譬重,WebSocket API 由 W3C 定為標(biāo)準(zhǔn)拒逮。仍在開(kāi)發(fā)中的 WebSocket 技術(shù)主要是為了解決 Ajax 和 Comet 里 XMLHttpRequest 附帶的缺陷所引起的問(wèn)題。

由于是建立在 HTTP 基礎(chǔ)上的協(xié)議臀规,因此連接的發(fā)起方仍是客戶(hù)端滩援,而一旦確立 WebSocket 通信連接,不論服務(wù)器還是客戶(hù)端塔嬉,任意一方都可直接向?qū)Ψ桨l(fā)送報(bào)文玩徊。

Paste_Image.png

構(gòu)建 Web 內(nèi)容的技術(shù)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市邑遏,隨后出現(xiàn)的幾起案子佣赖,更是在濱河造成了極大的恐慌,老刑警劉巖记盒,帶你破解...
    沈念sama閱讀 216,372評(píng)論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件憎蛤,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡纪吮,警方通過(guò)查閱死者的電腦和手機(jī)俩檬,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)碾盟,“玉大人棚辽,你說(shuō)我怎么就攤上這事”龋” “怎么了屈藐?”我有些...
    開(kāi)封第一講書(shū)人閱讀 162,415評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀(guān)的道長(zhǎng)熙尉。 經(jīng)常有香客問(wèn)我联逻,道長(zhǎng),這世上最難降的妖魔是什么检痰? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,157評(píng)論 1 292
  • 正文 為了忘掉前任包归,我火速辦了婚禮,結(jié)果婚禮上铅歼,老公的妹妹穿的比我還像新娘公壤。我一直安慰自己,他們只是感情好椎椰,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,171評(píng)論 6 388
  • 文/花漫 我一把揭開(kāi)白布厦幅。 她就那樣靜靜地躺著,像睡著了一般慨飘。 火紅的嫁衣襯著肌膚如雪确憨。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,125評(píng)論 1 297
  • 那天,我揣著相機(jī)與錄音缚态,去河邊找鬼。 笑死堤瘤,一個(gè)胖子當(dāng)著我的面吹牛玫芦,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播本辐,決...
    沈念sama閱讀 40,028評(píng)論 3 417
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼桥帆,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了慎皱?” 一聲冷哼從身側(cè)響起老虫,我...
    開(kāi)封第一講書(shū)人閱讀 38,887評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎茫多,沒(méi)想到半個(gè)月后祈匙,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,310評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡天揖,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,533評(píng)論 2 332
  • 正文 我和宋清朗相戀三年夺欲,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片今膊。...
    茶點(diǎn)故事閱讀 39,690評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡些阅,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出斑唬,到底是詐尸還是另有隱情市埋,我是刑警寧澤,帶...
    沈念sama閱讀 35,411評(píng)論 5 343
  • 正文 年R本政府宣布恕刘,位于F島的核電站缤谎,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏雪营。R本人自食惡果不足惜弓千,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,004評(píng)論 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望献起。 院中可真熱鬧洋访,春花似錦、人聲如沸谴餐。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,659評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)岂嗓。三九已至汁展,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背食绿。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,812評(píng)論 1 268
  • 我被黑心中介騙來(lái)泰國(guó)打工侈咕, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人器紧。 一個(gè)月前我還...
    沈念sama閱讀 47,693評(píng)論 2 368
  • 正文 我出身青樓耀销,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親铲汪。 傳聞我的和親對(duì)象是個(gè)殘疾皇子熊尉,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,577評(píng)論 2 353

推薦閱讀更多精彩內(nèi)容

  • 本文是《圖解HTTP》讀書(shū)筆記的第二篇,主要包括此書(shū)的第六章內(nèi)容掌腰,因?yàn)榈诹碌膬?nèi)容較多狰住,而且比較重要,所以單獨(dú)寫(xiě)為...
    lijiankun24閱讀 1,363評(píng)論 0 6
  • 1. 網(wǎng)絡(luò)基礎(chǔ)TCP/IP HTTP基于TCP/IP協(xié)議族齿梁,HTTP屬于它內(nèi)部的一個(gè)子集催植。 把互聯(lián)網(wǎng)相關(guān)聯(lián)的協(xié)議集...
    yozosann閱讀 3,443評(píng)論 0 20
  • 本篇文章篇幅比較長(zhǎng),先來(lái)個(gè)思維導(dǎo)圖預(yù)覽一下士飒。 一查邢、概述 1.計(jì)算機(jī)網(wǎng)絡(luò)體系結(jié)構(gòu)分層 2.TCP/IP 通信傳輸流 ...
    滌生_Woo閱讀 54,998評(píng)論 24 557
  • 第一章:Web及網(wǎng)絡(luò)基礎(chǔ) TCP/IP是互聯(lián)網(wǎng)相關(guān)的各類(lèi)協(xié)議族的總稱(chēng),包含TCP酵幕、UDP扰藕、HTTP、FTP芳撒、IP邓深、...
    loneyzhou閱讀 389評(píng)論 0 1
  • 網(wǎng)絡(luò)基礎(chǔ)知識(shí) URL和URI URI(Uniform Resource Idenifier)統(tǒng)一資源標(biāo)識(shí)符。即由某...
    d9fc24a0c9a9閱讀 1,123評(píng)論 0 6