ios網絡請求 get——post 區別

1、同步請求可以從因特網請求數據,一旦發送同步請求,程序將停止用戶交互,直至服務器返回數據完成,纔可以進行下一步操作,


2、異步請求不會阻塞主線程,而會建立一個新的線程來操作,用戶發出異步請求後,依然可以對UI進行操作,程序可以繼續運行


3、GET請求,將參數直接寫在訪問路徑上。操作簡單,不過容易被外界看到,安全性不高,地址最多255字節;


4、POST請求,將參數放到body裏面。POST請求操作相對複雜,需要將參數和地址分開,不過安全性高,參數放在body裏面,不易被捕獲。


 


查看源碼打印?

001

1、     同步GET請求


    //第一步,創建URL


    NSURL *url = [NSURL URLWithString:@"http://api.hudong.com/iphonexml.do?type=focus-c"];


    //第二步,通過URL創建網絡請求


    NSURLRequest *request = [[NSURLRequest alloc]initWithURL:url cachePolicy:NSURLRequestUseProtocolCachePolicy timeoutInterval:10];


    //NSURLRequest初始化方法第一個參數:請求訪問路徑,第二個參數:緩存協議,第三個參數:網絡請求超時時間(秒)

  其中緩存協議是個枚舉類型包含:


      NSURLRequestUseProtocolCachePolicy(基礎策略)


      NSURLRequestReloadIgnoringLocalCacheData(忽略本地緩存)


      NSURLRequestReturnCacheDataElseLoad(首先使用緩存,如果沒有本地緩存,才從原地址下載)


      NSURLRequestReturnCacheDataDontLoad(使用本地緩存,從不下載,如果本地沒有緩存,則請求失敗,此策略多用於離線操作)


      NSURLRequestReloadIgnoringLocalAndRemoteCacheData(無視任何緩存策略,無論是本地的還是遠程的,總是從原地址重新下載)


      NSURLRequestReloadRevalidatingCacheData(如果本地緩存是有效的則不下載,其他任何情況都從原地址重新下載)


    //第三步,連接服務器


    NSData *received = [NSURLConnection sendSynchronousRequest:request returningResponse:nil error:nil];


    NSString *str = [[NSString alloc]initWithData:received encoding:NSUTF8StringEncoding];


    NSLog(@"%@",str);


2、同步POST請求


    //第一步,創建URL

044

 

045

    NSURL *url = [NSURL URLWithString:@"http://api.hudong.com/iphonexml.do"];

046

 

047

    //第二步,創建請求

048

 

049

    NSMutableURLRequest *request = [[NSMutableURLRequest alloc]initWithURL:url cachePolicy:NSURLRequestUseProtocolCachePolicy timeoutInterval:10];

050

 

051

    [request setHTTPMethod:@"POST"];//設置請求方式爲POST,默認爲GET

052

 

053

    NSString *str = @"type=focus-c";//設置參數

054

 

055

    NSData *data = [str dataUsingEncoding:NSUTF8StringEncoding];

056

 

057

    [request setHTTPBody:data];

058

 

059

    //第三步,連接服務器

060

 

061

     

062

 

063

    NSData *received = [NSURLConnection sendSynchronousRequest:request returningResponse:nil error:nil];

064

 

065

     

066

 

067

    NSString *str1 = [[NSString alloc]initWithData:received encoding:NSUTF8StringEncoding];

068

 

069

     

070

 

071

    NSLog(@"%@",str1);

072

3、異步GET請求

073

 

074

    //第一步,創建url

075

 

076

    NSURL *url = [NSURL URLWithString:@"http://api.hudong.com/iphonexml.do?type=focus-c"];

077

 

078

    //第二步,創建請求

079

 

080

    NSURLRequest *request = [[NSURLRequest alloc]initWithURL:url cachePolicy:NSURLRequestUseProtocolCachePolicy timeoutInterval:10];

081

 

082

    //第三步,連接服務器

083

 

084

    NSURLConnection *connection = [[NSURLConnection alloc]initWithRequest:request delegate:self];

085

4、異步POST請求

086

 

087

    //第一步,創建url

088

 

089

    NSURL *url = [NSURL URLWithString:@"http://api.hudong.com/iphonexml.do"];

090

 

091

    //第二步,創建請求

092

 

093

    NSMutableURLRequest *request = [[NSMutableURLRequest alloc]initWithURL:url cachePolicy:NSURLRequestUseProtocolCachePolicy timeoutInterval:10];

094

 

095

    [request setHTTPMethod:@"POST"];

096

 

097

    NSString *str = @"type=focus-c";

098

 

099

    NSData *data = [str dataUsingEncoding:NSUTF8StringEncoding];

100

 

101

    [request setHTTPBody:data];

102

 

103

    //第三步,連接服務器

104

 

105

    NSURLConnection *connection = [[NSURLConnection alloc]initWithRequest:request delegate:self];

106

 

107

5、異步請求的代理方法

108

 

109

//接收到服務器迴應的時候調用此方法

110

 

111

- (void)connection:(NSURLConnection *)connection didReceiveResponse:(NSURLResponse *)response

112

 

113

{

114

 

115

    NSHTTPURLResponse *res = (NSHTTPURLResponse *)response;

116

 

117

    NSLog(@"%@",[res allHeaderFields]);

118

 

119

    self.receiveData = [NSMutableData data];

120

 

121

   

122

 

123

                               

124

 

125

}

126

 

127

//接收到服務器傳輸數據的時候調用,此方法根據數據大小執行若干次

128

 

129

-(void)connection:(NSURLConnection *)connection didReceiveData:(NSData *)data

130

 

131

{

132

 

133

    [self.receiveData appendData:data];

134

 

135

}

136

 

137

//數據傳完之後調用此方法

138

 

139

-(void)connectionDidFinishLoading:(NSURLConnection *)connection

140

 

141

{

142

 

143

    NSString *receiveStr = [[NSString alloc]initWithData:self.receiveData encoding:NSUTF8StringEncoding];

144

 

145

    NSLog(@"%@",receiveStr);

146

 

147

}

148

 

149

//網絡請求過程中,出現任何錯誤(斷網,連接超時等)會進入此方法

150

 

151

-(void)connection:(NSURLConnection *)connection

152

 

153

 didFailWithError:(NSError *)error

154

 

155

{

156

 

157

    NSLog(@"%@",[error localizedDescription]); }

從表面的意思看get 和 post的區別get就是獲取數據,post就是發送數據。這個是誤區。其實兩者都可以的,在IOS向服務器發送請求裏面可以帶參數。


那麼這些誤區是怎麼出現的呢?先看看一下對http的解釋


一般在瀏覽器中輸入網址訪問資源都是通過GET方式;在FORM提交中,可以通過Method指定提交方式爲GET或者POST,默認爲GET提交 

Http定義了與服務器交互的不同方法,最基本的方法有4種,分別是GET,POST,PUT,DELETE 

URL全稱是資源描述符,我們可以這樣認爲:一個URL地址,它用於描述一個網絡上的資源,而HTTP中的GET,POST,PUT,DELETE就對應着對這個資源的查 ,改 ,增 ,刪 4個操作。到這裏,大家應該有個大概的瞭解了,GET一般用於獲取/查詢 資源信息,而POST一般用於更新 資源信息(個人認爲這是GET和POST的本質區別,也是協議設計者的本意,其它區別都是具體表現形式的差異 )。


再進一步瞭解下他們兩個的區別:


1. GET使用URL或Cookie傳參。而POST將數據放在BODY中。


2. GET的URL會有長度上的限制,則POST的數據則可以非常大。


3. POST比GET安全,因爲數據在地址欄上不可見。


這些也是有點誤區的,就像同步請求一定的慢嗎?


GET和POST與數據如何傳遞沒有關係?


 


GET和POST是由HTTP協議定義的。在HTTP協議中,Method和Data(URL, Body, Header)是正交的兩個概念,也就是說,使用哪個Method與應用層的數據如何傳輸是沒有相互關係的。


HTTP沒有要求,如果Method是POST數據就要放在BODY中。也沒有要求,如果Method是GET,數據(參數)就一定要放在URL中而不能放在BODY中。


那麼,網上流傳甚廣的這個說法是從何而來的呢?我在HTML標準中,找到了相似的描述。這和網上流傳的說法一致。但是這只是HTML標準對HTTP協議的用法的約定。怎麼能當成GET和POST的區別呢?


而且,現代的Web Server都是支持GET中包含BODY這樣的請求。雖然這種請求不可能從瀏覽器發出,但是現在的Web Server又不是隻給瀏覽器用,已經完全地超出了HTML服務器的範疇了。


HTTP協議對GET和POST都沒有對長度的限制?


HTTP協議明確地指出了,HTTP頭和Body都沒有長度的要求。而對於URL長度上的限制,有兩方面的原因造成:


1. 瀏覽器。據說早期的瀏覽器會對URL長度做限制。據說IE對URL長度會限制在2048個字符內(流傳很廣,而且無數同事都表示認同)。但我自己試了一下,我構造了90K的URL通過IE9訪問live.com,是正常的。網上的東西,哪怕是Wikipedia上的,也不能信。


2. 服務器。URL長了,對服務器處理也是一種負擔。原本一個會話就沒有多少數據,現在如果有人惡意地構造幾個幾M大小的URL,並不停地訪問你的服務器。服務器的最大併發數顯然會下降。另一種***方式是,把告訴服務器Content-Length是一個很大的數,然後只給服務器發一點兒數據,嘿嘿,服務器你就傻等着去吧。哪怕你有超時設置,這種故意的次次訪問超時也能讓服務器吃不了兜着走。有鑑於此,多數服務器出於安全啦、穩定啦方面的考慮,會給URL長度加限制。但是這個限制是針對所有HTTP請求的,與GET、POST沒有關係。


這個貌似聽着對點吧。


3.對於安全不安全講。


get:


.所謂安全的意味着該操作用於獲取信息而非修改信息。換句話說,GET請求一般不應產生副作用。就是說,它僅僅是獲取資源信息,就像數據庫查詢一樣,不會修改,增加數據,不會影響資源的狀態。 

* 注意:這裏安全的含義僅僅是指是非修改信息。


 


POST的安全性要比GET的安全性高。注意:這裏所說的安全性和上面GET提到的“安全”不是同個概念。上面“安全”的含義僅僅是不作數據修改,而這裏安全的含義是真正的Security的含義,比如:通過GET提交數據,用戶名和密碼將明文出現在URL上,因爲(1)登錄頁面有可能被瀏覽器緩存, (2)其他人查看瀏覽器的歷史紀錄,那麼別人就可以拿到你的賬號和密碼了,除此之外,使用GET提交數據還可能會造成Cross-site request forgery*** .


看出來區別了吧


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章