`
810364804
  • 浏览: 783640 次
文章分类
社区版块
存档分类
最新评论

IOS之同步请求、异步请求、GET请求、POST请求(转)

 
阅读更多

1、同步请求可以从因特网请求数据,一旦发送同步请求,程序将停止用户交互,直至服务器返回数据完成,才可以进行下一步操作,

2、异步请求不会阻塞主线程,而会建立一个新的线程来操作,用户发出异步请求后,依然可以对UI进行操作,程序可以继续运行

3、GET请求,将参数直接写在访问路径上。操作简单,不过容易被外界看到,安全性不高,地址最多255字节;

4、POST请求,将参数放到body里面。POST请求操作相对复杂,需要将参数和地址分开,不过安全性高,参数放在body里面,不易被捕获。


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
    NSURL *url = [NSURL URLWithString:@"http://api.hudong.com/iphonexml.do"];
    //第二步,创建请求
    NSMutableURLRequest *request = [[NSMutableURLRequest alloc]initWithURL:url cachePolicy:NSURLRequestUseProtocolCachePolicy timeoutInterval:10];
    [request setHTTPMethod:@"POST"];//设置请求方式为POST,默认为GET
    NSString *str = @"type=focus-c";//设置参数
    NSData *data = [str dataUsingEncoding:NSUTF8StringEncoding];
    [request setHTTPBody:data];
    //第三步,连接服务器
    
    NSData *received = [NSURLConnection sendSynchronousRequest:request returningResponse:nil error:nil];
    
    NSString *str1 = [[NSString alloc]initWithData:received encoding:NSUTF8StringEncoding];
    
    NSLog(@"%@",str1);

3、异步GET请求

//第一步,创建url
    NSURL *url = [NSURL URLWithString:@"http://api.hudong.com/iphonexml.do?type=focus-c"];
    //第二步,创建请求
    NSURLRequest *request = [[NSURLRequest alloc]initWithURL:url cachePolicy:NSURLRequestUseProtocolCachePolicy timeoutInterval:10];
    //第三步,连接服务器
    NSURLConnection *connection = [[NSURLConnection alloc]initWithRequest:request delegate:self];

4、异步POST请求

//第一步,创建url
    NSURL *url = [NSURL URLWithString:@"http://api.hudong.com/iphonexml.do"];
    //第二步,创建请求
    NSMutableURLRequest *request = [[NSMutableURLRequest alloc]initWithURL:url cachePolicy:NSURLRequestUseProtocolCachePolicy timeoutInterval:10];
    [request setHTTPMethod:@"POST"];
    NSString *str = @"type=focus-c";
    NSData *data = [str dataUsingEncoding:NSUTF8StringEncoding];
    [request setHTTPBody:data];
    //第三步,连接服务器
    NSURLConnection *connection = [[NSURLConnection alloc]initWithRequest:request delegate:self];



5、异步请求的代理方法


//接收到服务器回应的时候调用此方法
- (void)connection:(NSURLConnection *)connection didReceiveResponse:(NSURLResponse *)response
{
    NSHTTPURLResponse *res = (NSHTTPURLResponse *)response;
    NSLog(@"%@",[res allHeaderFields]);
    self.receiveData = [NSMutableData data];
  

                              
}
//接收到服务器传输数据的时候调用,此方法根据数据大小执行若干次
-(void)connection:(NSURLConnection *)connection didReceiveData:(NSData *)data
{
    [self.receiveData appendData:data];
}
//数据传完之后调用此方法
-(void)connectionDidFinishLoading:(NSURLConnection *)connection
{
    NSString *receiveStr = [[NSString alloc]initWithData:self.receiveData encoding:NSUTF8StringEncoding];
    NSLog(@"%@",receiveStr);
}
//网络请求过程中,出现任何错误(断网,连接超时等)会进入此方法
-(void)connection:(NSURLConnection *)connection
 didFailWithError:(NSError *)error
{
    NSLog(@"%@",[error localizedDescription]);


分享到:
评论

相关推荐

    iOS之同步请求、异步请求、GET请求、POST请求

    关于iOS之同步请求、异步请求、GET请求、POST请求的解释与代码事例

    ios同步、异步、get与post请求介绍

    ios同步、异步、get与post请求的简单介绍

    全面解析iOS中同步请求、异步请求、GET请求、POST请求

    通过本文给大家全面解析了iOS中同步请求、异步请求、GET请求、POST请求,非常不错,具有参考借鉴价值,感兴趣的朋友一起学习吧

    iOS 同步异步网络请求

    iOS POST GET 同步 异步 网络请求。

    ios 利用http 向服务器请求数据

    同步GET请求 同步POST请求 异步GTE请求 异步POST请求 最简单的实现demo,一看就懂,新手必备。

    vue axios同步请求解决方案

    在vue项目里面,需要循环发送ajax请求,出现的问题就是循环结束,第一次服务器还没返回,导致数据处理错误,需要使用同步请求 解决方案 目前没有发现axios可以同步请求,所以只能使用jQuery,配置同步请求; $.ajax...

    vuejs使用axios异步访问时用get和post的实例讲解

    script中。 let data={....}; let url=xx; 方法各异: GET: this.$ajax.get(url,{ params:data ...POST: ... //请求后台数据之前转换入参 let url = xx; let data = { uname:this.uname, upwd:

    封转http网络下载

    自定义的网络下载,支持同步,异步 ,post, get 四种方式混合下载,其中异步下载透过代码块传值实现。

    关于vue中的ajax请求和axios包问题

    今天我说的是axios的post请求 github源文件及文档地址:【https://github.com/axios/axios】 + 首先,引入axios CDN: [removed][removed] npm: npm install axios 并在全局的js中引入:import axios from 'axios';...

    ios-ARHttpRequest.zip

    1、提供简明的网络操作API,包括get / post / postJson / postXml / postSoapXml / postFormData / downloadFile / uploadFile等。 2、downloadFile支持断点续传。 3、默认网络操作都为异步方式,提供完成/...

    vue结合axios与后端进行ajax交互的方法

    页面异步发出get请求获取数据,提交表单异步post数据到服务端 客户端 客户端代码 代码解析: // 服务端请求地址 let url = 'http://local.php.com/index.php'; let vm = new Vue({ el: "#app", data: { list: ...

    ShazamLite:一个用于Swift:high_voltage:的异步,易于使用且快速的HTTP网络库

    提供对所有HTTP请求类型(GET,POST,PUT,PATCH,DELETE)的支持。 常见HTTP错误的优美处理。 动态和自定义的请求构造。 服务器响应的自定义句柄。要求迅捷4.2+ Xcode 10.2以上iOS 10.0安装对于带有iOS 10.0+项目...

    ZZLib:一些用于 iPhone 开发的实用程序

    HTTP 请求支持:GET、POST、PUT 一些有用的宏和函数: ZZIsPad , ZZRGBA , ZZIs5 (检测 iPhone 5), ZZIs7 (检测 iOS 7) 简单的文本实用程序,例如大写等 在子视图中递归设置字体的类别 安装 克隆存储库:git://...

    Tiny.RestClient:.NET的最简单Fluent REST客户端

    Tiny.RestClient促进了API与应用程序之间的对话。 它隐藏了通讯,反序列化的... 支持动词:GET,POST,PUT,DELETE,PATCH和自定义http动词 支持ETag 支持多部分表格数据 支持每个请求的取消令牌 支持:下载文件和上

    支持数据从网络上下载和缓存功能

    该源码实现了支持数据从网络上下载和缓存功能,该功能不但可以提供简单易用,而且该功能齐全的数据异步下载,特别是对图片下载,以及和缓存功能,可以... 可以通过GET 或者 POST 方式获取数据; 9. 数据异步下载。

    Android学习系列教程实例.pdf

    iOS ....................................................................... 2 Android ................................................................ 2 Windows Phone ....................................

Global site tag (gtag.js) - Google Analytics