說明:apache tomcat伺服器必須占用8080端口
一、url
1.基本介紹
url的全稱是uniform resource locator(統一資源定位符)
通過1個url,能找到網際網路上唯一的1個資源
url就是資源的位址、位置,網際網路上的每個資源都有一個唯一的url

2.url中常見的協定
(1)http
超文本傳輸協定,通路的是遠端的網絡資源,格式是http://
http協定是在網絡開發中最常用的協定
(2)file
通路的是本地計算機上的資源,格式是file://(不用加主機位址)
(3)mailto
通路的是電子郵件位址,格式是mailto:
(4)ftp
通路的是共享主機的檔案資源,格式是ftp://
二、http協定
1.http協定簡介
不管是移動用戶端還是pc端,通路遠端的網絡資源經常使用http協定
通路百度首頁:http://www.baidu.com
獲得新浪的微網誌資料
獲得大衆點評的團購資料
2.http協定的作用
http的全稱是hypertext transfer protocol,超文本傳輸協定
(1)規定用戶端和伺服器之間的資料傳輸格式
(2)讓用戶端和伺服器能有效地進行資料溝通
3.為什麼選擇使用http?
(1)簡單快速 因為http協定簡單,是以http伺服器的程式規模小,因而通信速度很快
(2)靈活 http允許傳輸任意類型的資料
(3)http 0.9和1.0使用非持續連接配接 限制每次連接配接隻處理一個請求,伺服器對用戶端的請求做出響應後,馬上斷開連接配接,這種方式可以節省傳輸時間
4.http的通信過程
要想使用http協定向伺服器索取資料,得先了解http通信的完整過程
完整的http通信可以分為2大步驟
(1)請求:用戶端向伺服器索要資料
(2)響應:伺服器傳回用戶端相應的資料
三、http通信過程 - 請求和響應
1.http通信過程 - 請求
http協定規定:1個完整的由用戶端發給伺服器的http請求中包含以下内容
請求行:包含了請求方法、請求資源路徑、http協定版本
get /mjserver/resources/images/1.jpg http/1.1
請求頭:包含了對用戶端的環境描述、用戶端請求的主機位址等資訊
host: 192.168.1.105:8080 // 用戶端想通路的伺服器主機位址
user-agent: mozilla/5.0 (macintosh; intel mac os x 10.9) firefox/30.0// 用戶端的類型,用戶端的軟體環境
accept: text/html, */*// 用戶端所能接收的資料類型
accept-language: zh-cn // 用戶端的語言環境
accept-encoding: gzip // 用戶端支援的資料壓縮格式
請求體:用戶端發給伺服器的具體資料,比如檔案資料
2.http通信過程 - 響應
用戶端向伺服器發送請求,伺服器應當做出響應,即傳回資料給用戶端
http協定規定:1個完整的http響應中包含以下内容:
狀态行:包含了http協定版本、狀态碼、狀态英文名稱
http/1.1 200 ok
響應頭:包含了對伺服器的描述、對傳回資料的描述
server: apache-coyote/1.1 // 伺服器的類型
content-type: image/jpeg // 傳回資料的類型
content-length: 56811 // 傳回資料的長度
date: mon, 23 jun 2014 12:54:52 gmt // 響應的時間
實體内容:伺服器傳回給用戶端的具體資料,比如檔案資料
3.補充:推薦工具firebug-1.12.5-fx.xpi
蟲子的作用:攔截所有的http請求。
4.常見的響應狀态碼
四、發送http請求的方法
1.簡單說明
在http/1.1協定中,定義了8種發送http請求的方法
get、post、options、head、put、delete、trace、connect、patch
根據http協定的設計初衷,不同的方法對資源有不同的操作方式
put :增
delete :删
post:改
get:查
提示:最常用的是get和post(實際上get和post都能辦到增删改查)
2.get和post請求
要想使用get和post請求跟伺服器進行互動,得先了解一個概念:參數就是傳遞給伺服器的具體資料,比如登入時的帳号、密碼
get和post對比:get和post的主要差別表現在資料傳遞上
get
注意:由于浏覽器和伺服器對url長度有限制,是以在url後面附帶的參數是有限制的,通常不能超過1kb
post
發給伺服器的參數全部放在請求體中
理論上,post傳遞的資料量沒有限制(具體還得看伺服器的處理能力)
3.get和post的選擇
選擇get和post的建議
(1)如果要傳遞大量資料,比如檔案上傳,隻能用post請求
(2)get的安全性比post要差些,如果包含機密\敏感資訊,建議用post
(3)如果僅僅是索取資料(資料查詢),建議使用get
(4)如果是增加、修改、删除資料,建議使用post
4.ios中發送http請求的方案
在ios中,常見的發送http請求(get和post)的解決方案有
(1)蘋果原生(自帶)
nsurlconnection:用法簡單,最古老最經典最直接的一種方案
nsurlsession:ios 7新出的技術,功能比nsurlconnection更加強大
cfnetwork:nsurl*的底層,純c語言
(2)第三方架構
asihttprequest:外号“http終結者”,功能極其強大,可惜早已停止更新
afnetworking:簡單易用,提供了基本夠用的常用功能
建議:
為了提高開發效率,企業開發用的基本是第三方架構
5.asi和afn架構對比
說明:afn基于nsurl,asi基于cfhttp,asi的性能更好一些。