基本概念

客戶端(Client):移動應用(iOS、android等應用)
服務器(Server):為客戶端提供服務、提供數(shù)據(jù)、提供資源的機器
請求(Request):客戶端向服務器索取數(shù)據(jù)的一種行為
響應(Response):服務器對客戶端的請求做出的反應,一般指返回數(shù)據(jù)給客戶端

移動端想顯示網(wǎng)絡上的數(shù)據(jù),分兩個步驟:1.發(fā)一個請求給服務器;2.解析服務器返回響應

服務器

一、遠程服務器(正式服務器),即應用上線之后使用的服務器;
二、本地服務器(測試服務器),開發(fā)測試

HTTP

如何找到服務器

網(wǎng)絡中有著各式各樣的服務器,那么怎么找到呢?即客戶端如何連接服務器?通過URL找到想要連接的服務器。

URL

Uniform Resource Locator(統(tǒng)一資源定位符)
通過一個URL,能夠遭到互聯(lián)網(wǎng)上唯一的一個資源
URL就是資源的地址、位置,互聯(lián)網(wǎng)上的每一個資源都有唯一的URL

URL的基本格式 = 協(xié)議://主機地址/路徑
https://www.baidu.com/*****
協(xié)議:不同的協(xié)議,代表著不同的資源查找方式、資源傳輸方式
主機地址:存放資源的主機(服務器)的IP地址(域名)
路徑:資源在主機(服務器)中的具體位置

URL中常見的協(xié)議

HTTP
超文本傳輸協(xié)議,訪問遠程網(wǎng)絡資源,格式是 http://

file
訪問的是本地計算機上的資源,格式是file://(不用加主機地址)

mailto
訪問的是電子郵件地址,格式是mailto:

FTP
訪問的是共享主機的文件資源,格式是ftp://

HTTP協(xié)議簡介

不管是移動客戶端還是PC端,訪問遠程的網(wǎng)絡資源經(jīng)常使用HTTP協(xié)議。客戶端給服務器發(fā)送怎樣格式的數(shù)據(jù)給服務器,服務器才能看懂?
服務器該返回什么格式的數(shù)據(jù)給客戶端,客戶端才能看懂?
兩邊要怎樣傳輸數(shù)據(jù)才能有效溝通?

HTTP協(xié)議的作用
HTTP的全稱是Hypertext Transfer Protocol,超文本傳輸協(xié)議;
規(guī)定客戶端和服務器之間的數(shù)據(jù)傳輸格式;
讓客戶端和服務器能有效地進行數(shù)據(jù)溝通。

HTTP協(xié)議的特點

簡單快速
因為HTTP協(xié)議簡單,所以HTTP服務器的程序規(guī)模小,因而通信速度很快
靈活
HTTP允許傳輸各種各樣的數(shù)據(jù)

完整的http通信可以分為2大步驟
請求:客戶端向服務器索要數(shù)據(jù)
響應:服務器返回客戶端相應的數(shù)據(jù)
開發(fā)中,要會如何給服務器發(fā)送請求,如何解析服務器返回給客戶端的數(shù)據(jù)

發(fā)送HTTP請求的方法

根據(jù)HTTP協(xié)議的設計初衷,不同的方法對資源有不同的操作方式
最常用的是GET和POST(實際上GET和POST都能辦到增刪改查)

要想使用GET和POST請求跟服務器進行交互,得先了解一個概念
參數(shù)
就是傳遞給服務器的具體數(shù)據(jù),比如登錄時的帳號、密碼

GET和POST對比

GET和POST的主要區(qū)別表現(xiàn)在數(shù)據(jù)傳遞上
GET
在請求URL后面以?的形式跟上發(fā)給服務器的參數(shù),多個參數(shù)之間用&隔開,比如http://ww.test.com/login?username=123&pwd=234&type=JSON
由于瀏覽器和服務器對URL長度有限制,因此在URL后面附帶的參數(shù)是有限制的,通常不能超過1KB

POST
發(fā)給服務器的參數(shù)全部放在請求體
理論上,POST傳遞的數(shù)據(jù)量沒有限制(具體還得看服務器的處理能力)

GET和POST的選擇

選擇GET和POST的建議
》如果要傳遞大量數(shù)據(jù),比如文件上傳,只能用POST請求
》GET的安全性比POST要差些,如果包含機密\敏感信息,建議用POST
》如果僅僅是索取數(shù)據(jù)(數(shù)據(jù)查詢),建議使用GET
》如果是增加、修改、刪除數(shù)據(jù),建議使用POST

iOS中發(fā)送HTTP請求的方案

蘋果原生(自帶)
》NSURLConnection:用法簡單,最古老最經(jīng)典最直接的一種方案【坑比較多】
》》NSURLSession:功能比NSURLConnection更加強大,蘋果目前比較推薦使用這種技術(shù)【2013推出,iOS7開始出的技術(shù)】
》CFNetwork:NSURL*的底層,純C語言
》第三方框架
-ASIHttpRequest:外號“HTTP終結(jié)者”,功能極其強大,可惜早已停止更新
-》AFNetworking:簡單易用,提供了基本夠用的常用功能,維護和使用者多
-MKNetworkKit:簡單易用,產(chǎn)自三哥的故鄉(xiāng)印度,維護和使用者少
》建議
為了提高開發(fā)效率,企業(yè)開發(fā)用的基本是第三方框架

HTTP通信過程 - 請求

請求頭:包含了 對客戶端環(huán)境的描述、客戶端請求信息等

GET /minion.png HTTP/1.1 // 包含了請求方法、請求資源路徑、HTTP協(xié)議版本
Host: 120.25.226.186:32812 // 客戶端想訪問的服務器主機地址
User-Agent: Mozilla/5.0 // 客戶端的類型,客戶端的軟件環(huán)境
Accept: text/html, / // 客戶端所能接收的數(shù)據(jù)類型
Accept-Language: zh-cn // 客戶端的語言環(huán)境
Accept-Encoding: gzip // 客戶端支持的數(shù)據(jù)壓縮格式

請求體:客戶端發(fā)給服務器的具體數(shù)據(jù),比如文件數(shù)據(jù)(POST請求才會有)

HTTP通信過程 - 響應

客戶端向服務器發(fā)送請求,服務器應當做出響應,即返回數(shù)據(jù)給客戶端
HTTP協(xié)議規(guī)定:1個完整的HTTP響應中包含以下內(nèi)容
響應頭:包含了對服務器的描述、對返回數(shù)據(jù)的描述

HTTP/1.1 200 OK // 包含了HTTP協(xié)議版本、狀態(tài)碼、狀態(tài)英文名稱
Server: Apache-Coyote/1.1 // 服務器的類型
Content-Type: image/jpeg // 返回數(shù)據(jù)的類型
Content-Length: 56811 // 返回數(shù)據(jù)的長度
Date: Mon, 23 Jun 2014 12:54:52 GMT // 響應的時間

響應體:服務器返回給客戶端的具體數(shù)據(jù),比如文件數(shù)據(jù)

HTTP通信過程.png

URL

URL 全稱是Uniform Resource Locator,即統(tǒng)一資源定位符,通過一個URL,可以找到互聯(lián)網(wǎng)上唯一的一個資源
URL就是資源的地址、位置,互聯(lián)網(wǎng)上每個資源都有UI個唯一的URL
基本格式:協(xié)議://主機地址/路徑
-協(xié)議:不同的協(xié)議,代表著不同的資源查找方式,資源傳輸方式
-主機地址:存放資源的主機的IP地域
-路徑:資源在主機中的位置

HTTP 超文本傳輸協(xié)議

HTTP是一個應用層協(xié)議,由請求和響應構(gòu)成,是一個標準的客戶端服務器模型
HTTP 在客戶端和服務器交互時:三次握手
巧了!什么是三次握手呢?
比如:A給B打電話,B:喂(第一次響應)A:喂(第二次響應)老王啊。。。(第三次響應)
<li>

F{}GK0ZSKWF24H$1TRS2KIH.jpg

</li>

HTTPS安全超文本傳輸協(xié)議

其使用SSL(安全套接字層)進行信息交換,在發(fā)送方把原始數(shù)據(jù)進行加密,然后在接收方進行解密,且雙方有共知的密鑰實現(xiàn)(安全性)。

![G$ZMZ[YTLR7@FMD{W$]SH1.jpg

HTTP協(xié)議的常見請求方式

<li>GET
<li>POST

相同點

給服務器傳輸數(shù)據(jù)

不同點

1.給服務器傳輸?shù)姆绞讲煌?br> GET:通過網(wǎng)址字符串;
POST:通過data
2.傳輸數(shù)據(jù)的大小不同
GET:最多255字節(jié)
POST:容量超過1G
3.安全性
GET:類似于密碼的明文輸入,直接可見
PIST:數(shù)據(jù)被轉(zhuǎn)成二進制數(shù)據(jù),類似于密碼的秘聞輸入,無法直接讀取


FQX3UX)_70SOG7PNVF)6DFJ.jpg
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關(guān)閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,554評論 19 139
  • 一.URL簡述 1.什么是URL URL的全稱是Uniform Resource Locator(統(tǒng)一資源定位符)...
    篤Boy閱讀 378評論 0 0
  • 1. 在網(wǎng)絡編程中,有幾個必須掌握的基本概念 客戶端(Client): 移動應用(iOS、Android等應用) ...
    WenJim閱讀 2,060評論 0 0
  • 一、概念(載錄于:http://www.cnblogs.com/EricaMIN1987_IT/p/3837436...
    yuantao123434閱讀 8,741評論 6 152
  • “今晚,我想跟大家講講愛國,講講我們可以怎么來愛國。為此,我想做一個調(diào)查,問大家一個問題?!?學生們坐直了身子,有...
    小鹿says閱讀 349評論 0 3

友情鏈接更多精彩內(nèi)容