從輸入url到頁面加載的過程

1)把URL分割成幾個部分:協議、網絡地址、資源路徑。其中網絡地址指示該鏈接網絡上哪一臺計算機,能夠是域名或者IP地址,能夠包括端口號;協議是從該計算機獲取資源的方式,常見的是HTTP、FTP,不一樣協議有不一樣的通信內容格式;資源路徑指示從服務器上獲取哪一項資源。 例如:http://www.guokr.com/question/554991/ 協議部分:http 網絡地址:www.guokr.com 資源路徑:/question/554991/瀏覽器

2)若是地址不是一個IP地址,經過DNS(域名系統)將該地址解析成IP地址。IP地址對應着網絡上一臺計算機,DNS服務器自己也有IP,你的網絡設置包含DNS服務器的IP。 例如:www.guokr.com 不是一個IP,向DNS詢問請求www.guokr.com 對應的IP,得到IP: 111.13.57.142。這個過程裏,你的電腦直接詢問的DNS服務器可能沒有www.guokr.com 對應的IP,就會向它的上級服務器詢問,上級服務器一樣可能沒有,就依此一層層向上找,最高可達根節點,找到或者所有找不到爲止。服務器

3)若是地址不包含端口號,根據協議的默認端口號肯定一個。端口號之於計算機就像窗口號之於銀行,一家銀行有多個窗口,每一個窗口都有個號碼,不一樣窗口能夠負責不一樣的服務。端口只是一個邏輯概念,和計算機硬件沒有關係。 例如:www.guokr.com 不包含端口號,http協議默認端口號是80。若是你輸入的url是http://www.guokr.com:8080/ ,那表示不使用默認的端口號,而使用指定的端口號8080。網絡

4)向2和3肯定的IP和端口號發起網絡鏈接。 例如:向111.13.57.142的80端口發起鏈接佈局

5)根據http協議要求,組織一個請求的數據包,裏面包含大量請求信息,包括請求的資源路徑、你的身份 例如:用天然語言來表達這個數據包,大概就是:請求 /question/554991/ ,個人身份是xxxxxxx。url

6)服務器響應請求,將數據返回給瀏覽器。數據多是根據HTML協議組織的網頁,裏面包含頁面的佈局、文字。數據也多是圖片、腳本程序等。如今你能夠用瀏覽器的「查看源代碼」功能,感覺一下服務器返回的是什麼東東。若是資源路徑指示的資源不存在,服務器就會返回著名的404錯誤。圖片

7)若是(6)返回的是一個頁面,根據頁面裏一些外鏈的URL,例如圖片的地址,按照(1)-(6)再次獲取。資源

8)開始根據資源的類型,將資源組織成屏幕上顯示的圖像,這個過程叫渲染,網頁渲染是瀏覽器最複雜、最核心的功能。get

9)將渲染好的頁面圖像顯示出來,並開始響應用戶的操做。域名

相關文章
相關標籤/搜索