NSURLComponents 使用簡介 - iOS

該類蘋果在 iOS 7中添加,它(NSURLComponents)可以方便的把 URL 地址分解成多個部分;

其中, URL(Uniform Resource Locator)地址用于描述一個網(wǎng)絡上的資源,基本格式如下:

schema://host[:port#]/path/.../[?query-string][#anchor]

schema:指定低層使用的協(xié)議,例如 http https ftp 等.

host:HTTP 服務器的 IP 地址或者域名

port#:HTTP 服務器的默認端口是80,該情況下端口號可以省略.(注:如果使用其它端口,必須將其指明,例如: http://www.itdecent.cn:8080/)

path:訪問資源的路徑

query-string: 發(fā)送給 http 服務器的數(shù)據(jù)

anchor: 錨


例如:

直接上 code:

NSString *urlStr =@"http://bbs.csdn.net/forums/ios";

NSURLComponents *components = [NSURLComponents componentsWithString:urlStr];

NSString *host = components.host;

NSString *user = components.user;

NSString *pwd = components.password;

NSNumber *port = components.port;

NSString *path = components.path;

NSString *query = components.query;

NSString *fragment = components.fragment;

NSLog(@"\n host --- %@\n path --- %@\n user --- %@\n pwd --- %@\n port --- %@\n query --- %@\n fragment --- %@\n", host, path, user, pwd, port, query, fragment);

打印結果如下:

host --- bbs.csdn.net

path --- /forums/ios

user --- (null)

pwd --- (null)

port --- (null)

query --- (null)

fragment --- (null)

如上結果得出,根據(jù)不同的 URL 地址,可以利用如上方法進行地址切割,得出相對應的部分,從而進行選取有用的部分進一步執(zhí)行相關操作.

(如上地址只是隨機使用了一個較為簡單的 URL 地址,實際開發(fā)將其切換成實際地址即可.)


拓展:

首先,HTTP 協(xié)議是無狀態(tài)的,同一個客戶端的本次請求和上次請求都是沒有任何關聯(lián)關系的,對 http 服務器而言并不能分辨當前請求的具體來源,但將 web 程序引入 cookie 機制可解決該問題.

其次,Request 的消息結構分為三部分,其一稱為 Request line, 其二稱為 Request header, 其三稱為 body.head 和 body;

再其次, ?Http 協(xié)議定義了很多與服務器交互相關的方法,其中最基本的四種為 GET,POST,PUT,DELETE, 一個 URL 地址用于描述一個網(wǎng)絡上的資源,而 HTTP 中交互的方法就對應著該資源的增刪改查操作.通常所見所用的基本都是 GET 和 POST 這兩種.

Get 一般用于獲取和查詢資源信息時使用;

Post 一般用于提交和更新資源信息時使用.

其區(qū)別在于:

1.Get 提交的數(shù)據(jù)會裝在 URL 之后,以問號("?")分隔 URL 和傳輸數(shù)據(jù),而參數(shù)之間以("&")符號相連;

Post 則是將提交的數(shù)據(jù)裝在 Http 包的 Body 中.

2.因瀏覽器對 URL 長度的限制,GET 提交的數(shù)據(jù)大小是有限制的,而 POST 方法提交的數(shù)據(jù)沒有該限制.

3.Get 方式需要使用 Request.QueryString 來取得變量的值,而 Post 方式通過 Request.Form 來獲取變量的值.

4.在提交數(shù)據(jù)的安全方面 Get 方法要劣與 Post 方法,因為使用 Get 方法進行數(shù)據(jù)提交會將一些數(shù)據(jù)信息暴露在 URL 鏈接中,如果頁面被緩存或者被他人抓包,則會導致數(shù)據(jù)信息的泄露.


狀態(tài)碼相關:

狀態(tài)碼用于告知客戶端服務器是否產(chǎn)生了 Response, 其中 Response 消息中第一行為狀態(tài)行,是由 HTTP 協(xié)議版本號 狀態(tài)碼 狀態(tài)消息三部分組成.?

狀態(tài)碼是由三位數(shù)字組成,具體如下:

1xx 即表示請求已成功接收,繼續(xù)處理;

2xx 即表示請求已成功接收,受理;

3xx 即表示要完成請求必須進行更進一步的處理;

4xx 即表示請求語法異常;

5xx 即表示服務器未能實現(xiàn)合法請求.

常見的一些狀態(tài)碼:

200 成功;

302 發(fā)現(xiàn)新的 URL 并將其在 location 中返回且瀏覽器自動使用該 URL 重新請求;

304 之前的文檔也緩存可繼續(xù)使用;

400 客戶端請求語法錯誤,服務器不能受理服務;

403 服務器收到請求,但拒絕受理服務;

404 最常見的異常,錯誤的 URL 所請求的資源不存在;

500 服務器服務了不可預期的錯誤;

503 服務器當前不能處理客戶請求,稍后可能恢復.

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

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

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