“URL小能手”NSURLComponents

背景
  • 在項目開發(fā)中,移動原生應用會經(jīng)常嵌入一些H5頁面,根據(jù)不同的業(yè)務場景,可能需要移動端拼接上不同的業(yè)務參數(shù)枫吧。(比如展示一個訂單詳情浦旱,后端返回了一個baseURL,我們需要拼接訂單號九杂,或者是其他的業(yè)務flag)颁湖。那么這個時候端上為了容錯,有些時候會判斷后端返回的URL中的一些特殊符號(?例隆、&甥捺,&&...),根據(jù)是否有相應的拼接符進行不同的起始拼接镀层。
if ([urlPath rangeOfString:@"?"].location == NSNotFound) {
    urlPath = [urlPath stringByAppendingFormat:@"?orderId=%@&type=%lu&lang=%@&cityId=%ld", orderId,type,lang,cityId];
} else {
    urlPath = [urlPath stringByAppendingFormat:@"orderId=%@&type=%lu&lang=%@&cityId=%ld", orderId,type,lang,cityId];
}

諸如此類的代碼镰禾,不知道有多少小伙伴踩過坑~

  • WebView加載的頁面地址中提取參數(shù)(估計又有很多小伙伴會根據(jù)&進行字符串的分割...)

那么這個時候如果使用NSURLComponents進行組合和分解將會事半功倍。

相關知識延伸

在一維數(shù)據(jù)類型中,URI占據(jù)了至高無上的地位吴侦。這里屋休,在單個的,可解析的字符串中备韧,是編碼在計算機上具有劫樟,確實和將要存在的任何信息的位置所必需的每條可想到的信息。

在最基本的形式中织堂,URI由方案名稱和層次結構部分組成叠艳,帶有可選的查詢和片段:

<scheme name> : <hierarchical part> [ ? <query> ] [ # <fragment> ]

許多協(xié)議(包括HTTP)為層次結構部分中的用戶名,密碼易阳,端口和路徑等信息指定常規(guī)結構:

網(wǎng)址結構

扎實地掌握網(wǎng)絡編程,做到對URL組件的熟悉附较。

NSURLComponents

NSURLComponents 在iOS 7.0和macOS 10.9中引入的,所以從時間上看已經(jīng)是存在一段時間了闽烙。
要創(chuàng)建NSURLComponents對象翅睛,您可以使用a String或an URL

正如官方文檔所描述:

If resolvingAgainstBaseURL is true and url is a relative URL, the components of url.absoluteURL are used. If the url string from the URL is malformed, nil is returned.

下面我們就根據(jù)下面的代碼黑竞,進行一個簡單的介紹分析

NSString * urlString = @"http://image.baidu.com/search/index?tn=baiduimage&ps=1&ct=201326592&lm=-1&cl=2&nc=1&ie=utf-8&word=image";
NSURLComponents * urlComponents = [[NSURLComponents alloc]initWithString:urlString];
NSLog(@"urlComponents.host = \n%@",urlComponents.host);//>>image.baidu.com
NSLog(@"urlComponents.scheme = \n%@",urlComponents.scheme);//>>http
NSLog(@"urlComponents.path = \n%@",urlComponents.path);//>>/search/index
NSLog(@"urlComponents.query = \n%@",urlComponents.query);//>>tn=baiduimage&ps=1&ct=201326592&lm=-1&cl=2&nc=1&ie=utf-8&word=image

這個時候大家會不會就有眼前一亮的感覺??
如果在配合下面一句呢

 NSLog(@"urlComponents.ququeryItems=%@",urlComponents.queryItems);//>>(
    "<NSURLQueryItem 0x6000016fe720> {name = tn, value = baiduimage}",
    "<NSURLQueryItem 0x6000016fe740> {name = ps, value = 1}",
    "<NSURLQueryItem 0x6000016fe760> {name = ct, value = 201326592}",
    "<NSURLQueryItem 0x6000016fe780> {name = lm, value = -1}",
    "<NSURLQueryItem 0x6000016fe7a0> {name = cl, value = 2}",
    "<NSURLQueryItem 0x6000016fe7c0> {name = nc, value = 1}",
    "<NSURLQueryItem 0x6000016fe7e0> {name = ie, value = utf-8}",
    "<NSURLQueryItem 0x6000016fe800> {name = word, value = image}"
)

可以看出捕发,為我們提供了一個NSURLQueryItem,各個查詢項的鍵/值對象,這使我們更容易追加查詢參數(shù),或檢查URL是否包含查詢參數(shù)很魂。

按照這個思路扎酷,各位小伙伴,現(xiàn)在是不是可以放飛自我了??遏匆,對已有的URL進行盡情的組合法挨,分解。

拼裝
NSURLQueryItem * item = [[NSURLQueryItem alloc]initWithName:@"imageSize" value:@"1024*1024"];
NSMutableArray * items = [NSMutableArray arrayWithArray:urlComponents.queryItems];
[items addObject:item];
urlComponents.queryItems = [items copy];
NSLog(@"urlComponents.ququeryItems=%@",urlComponents.queryItems);//>>(
    "<NSURLQueryItem 0x6000037712a0> {name = tn, value = baiduimage}",
    "<NSURLQueryItem 0x6000037712c0> {name = ps, value = 1}",
    "<NSURLQueryItem 0x6000037712e0> {name = ct, value = 201326592}",
    "<NSURLQueryItem 0x600003771300> {name = lm, value = -1}",
    "<NSURLQueryItem 0x600003771320> {name = cl, value = 2}",
    "<NSURLQueryItem 0x600003771340> {name = nc, value = 1}",
    "<NSURLQueryItem 0x600003771360> {name = ie, value = utf-8}",
    "<NSURLQueryItem 0x600003771380> {name = word, value = image}",
    "<NSURLQueryItem 0x6000037713a0> {name = imageSize, value = 1024*1024}"
)

再來打印一下urlComponents.query

NSLog(@"urlComponents.query = \n%@",urlComponents.query);//>>tn=baiduimage&ps=1&ct=201326592&lm=-1&cl=2&nc=1&ie=utf-8&word=image&imageSize=1024*1024

簡單而美觀幅聘,所有的辛勤工作都被委托給NSURLComponents凡纳,我們甚至不用擔心是否使用?&...

分解

如上述代碼,將數(shù)據(jù)遍歷帝蒿,就可以拿到單個的NSURLQueryItem,此時咱們可以處理 包含荐糜、去重等等操作,現(xiàn)在我們知道NSURLQueryItems檢查查詢參數(shù)是否存在太容易了葛超。??

現(xiàn)在在回頭看暴氏,現(xiàn)在的處理是不是更加的優(yōu)雅,便于維護绣张,便于擴展了呢答渔。

如果你想更好的運用和深入地了解,可以去apple官方文檔查閱侥涵。

參考資料
最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末沼撕,一起剝皮案震驚了整個濱河市宋雏,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌端朵,老刑警劉巖好芭,帶你破解...
    沈念sama閱讀 207,248評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異冲呢,居然都是意外死亡舍败,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,681評論 2 381
  • 文/潘曉璐 我一進店門敬拓,熙熙樓的掌柜王于貴愁眉苦臉地迎上來邻薯,“玉大人,你說我怎么就攤上這事乘凸〔薰睿” “怎么了?”我有些...
    開封第一講書人閱讀 153,443評論 0 344
  • 文/不壞的土叔 我叫張陵营勤,是天一觀的道長灵嫌。 經(jīng)常有香客問我,道長葛作,這世上最難降的妖魔是什么寿羞? 我笑而不...
    開封第一講書人閱讀 55,475評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮赂蠢,結果婚禮上绪穆,老公的妹妹穿的比我還像新娘。我一直安慰自己虱岂,他們只是感情好玖院,可當我...
    茶點故事閱讀 64,458評論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著第岖,像睡著了一般难菌。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上蔑滓,一...
    開封第一講書人閱讀 49,185評論 1 284
  • 那天郊酒,我揣著相機與錄音,去河邊找鬼烫饼。 笑死,一個胖子當著我的面吹牛试读,可吹牛的內(nèi)容都是我干的杠纵。 我是一名探鬼主播,決...
    沈念sama閱讀 38,451評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼钩骇,長吁一口氣:“原來是場噩夢啊……” “哼比藻!你這毒婦竟也來了铝量?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 37,112評論 0 261
  • 序言:老撾萬榮一對情侶失蹤银亲,失蹤者是張志新(化名)和其女友劉穎慢叨,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體务蝠,經(jīng)...
    沈念sama閱讀 43,609評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡拍谐,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,083評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了馏段。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片轩拨。...
    茶點故事閱讀 38,163評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖院喜,靈堂內(nèi)的尸體忽然破棺而出亡蓉,到底是詐尸還是另有隱情,我是刑警寧澤喷舀,帶...
    沈念sama閱讀 33,803評論 4 323
  • 正文 年R本政府宣布砍濒,位于F島的核電站,受9級特大地震影響硫麻,放射性物質(zhì)發(fā)生泄漏爸邢。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,357評論 3 307
  • 文/蒙蒙 一庶香、第九天 我趴在偏房一處隱蔽的房頂上張望甲棍。 院中可真熱鬧,春花似錦赶掖、人聲如沸感猛。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,357評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽陪白。三九已至,卻和暖如春膳灶,著一層夾襖步出監(jiān)牢的瞬間咱士,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,590評論 1 261
  • 我被黑心中介騙來泰國打工轧钓, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留序厉,地道東北人。 一個月前我還...
    沈念sama閱讀 45,636評論 2 355
  • 正文 我出身青樓毕箍,卻偏偏與公主長得像弛房,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子而柑,可洞房花燭夜當晚...
    茶點故事閱讀 42,925評論 2 344