(1)步骤ios
01 设置请求路径 02 建立请求对象(默认是GET请求,且已经默认包含了请求头) 03 使用NSURLSession sendsync方法发送网络请求 04 接收到服务器的响应后,解析响应体
(2)相关代码服务器
//1.肯定请求路径 NSURL *url = [NSURL URLWithString:@"http://120.25.226.186:32812/login?username=520it&pwd=520it&type=XML"]; // NSURL *url = [NSURL URLWithString:@"http://120.25.226.186:32812/video?type=XML"]; //2.建立一个请求对象 NSURLRequest *request = [NSURLRequest requestWithURL:url]; //3.把请求发送给服务器 //sendSynchronousRequest (同步)阻塞式的方法,会卡住线程 NSHTTPURLResponse *response = nil; NSError *error = nil; /* 第一个参数:请求对象 第二个参数:响应头信息,当该方法执行完毕以后,该参数被赋值 第三个参数:错误信息,若是请求失败,则error有值 */ //该方法是阻塞式的,会卡住线程 NSData *data = [NSURLConnection sendSynchronousRequest:request returningResponse:&response error:&error]; //4.解析服务器返回的数据 NSString *str = [[NSString alloc]initWithData:data encoding:NSUTF8StringEncoding];
(1)相关说明网络
01 该方法不会卡住当前线程,网络请求任务是异步执行的
(2)相关代码框架
//1.肯定请求路径 NSURL *url = [NSURL URLWithString:@"http://120.25.226.186:32812/login?username=520it&pwd=520it"]; //2.建立一个请求对象 NSURLRequest *request = [NSURLRequest requestWithURL:url]; //3.把请求发送给服务器,发送一个异步请求 /* 第一个参数:请求对象 第二个参数:回调方法在哪一个线程中执行,若是是主队列则block在主线程中执行,非主队列则在子线程中执行 第三个参数:completionHandlerBlock块:接受到响应的时候执行该block中的代码 response:响应头信息 data:响应体 connectionError:错误信息,若是请求失败,那么该参数有值 */ [NSURLConnection sendAsynchronousRequest:request queue:[[NSOperationQueue alloc]init] completionHandler:^(NSURLResponse * __nullable response, NSData * __nullable data, NSError * __nullable connectionError) { //4.解析服务器返回的数据 NSString *str = [[NSString alloc]initWithData:data encoding:NSUTF8StringEncoding]; //转换并打印响应头信息 NSHTTPURLResponse *r = (NSHTTPURLResponse *)response; NSLog(@"--%zd---%@--",r.statusCode,r.allHeaderFields); }];
(1)步骤异步
01 肯定请求路径 02 建立请求对象 03 建立NSURLConnection对象并设置代理 04 遵照NSURLConnectionDataDelegate协议,并实现相应的代理方法 05 在代理方法中监听网络请求的响应
(2)设置代理的几种方法ide
/* 设置代理的第一种方式:自动发送网络请求 [[NSURLConnection alloc]initWithRequest:request delegate:self]; */ /* 设置代理的第二种方式: 第一个参数:请求对象 第二个参数:谁成为NSURLConnetion对象的代理 第三个参数:是否立刻发送网络请求,若是该值为YES则马上发送,若是为NO则不会发送网路请求 NSURLConnection *conn = [[NSURLConnection alloc]initWithRequest:request delegate:self startImmediately:NO]; //调用该方法控制网络请求的发送 [conn start]; */ //设置代理的第三种方式:使用类方法设置代理,会自动发送网络请求 NSURLConnection *conn = [NSURLConnection connectionWithRequest:request delegate:self]; //取消网络请求 //[conn cancel];
(3)相关的代理方法oop
/* 1.当接收到服务器响应的时候调用 第一个参数connection:监听的是哪一个NSURLConnection对象 第二个参数response:接收到的服务器返回的响应头信息 */ - (void)connection:(nonnull NSURLConnection *)connection didReceiveResponse:(nonnull NSURLResponse *)response /* 2.当接收到数据的时候调用,该方法会被调用屡次 第一个参数connection:监听的是哪一个NSURLConnection对象 第二个参数data:本次接收到的服务端返回的二进制数据(多是片断) */ - (void)connection:(nonnull NSURLConnection *)connection didReceiveData:(nonnull NSData *)data /* 3.当服务端返回的数据接收完毕以后会调用 一般在该方法中解析服务器返回的数据 */ -(void)connectionDidFinishLoading:(nonnull NSURLConnection *)connection /*4.当请求错误的时候调用(好比请求超时) 第一个参数connection:NSURLConnection对象 第二个参数:网络请求的错误信息,若是请求失败,则error有值 */ - (void)connection:(nonnull NSURLConnection *)connection didFailWithError:(nonnull NSError *)error
(4)其它知识点url
01 关于消息弹窗第三方框架的使用 SVProgressHUD 02 字符串截取相关方法 - (NSRange)rangeOfString:(NSString *)searchString; - (NSString *)substringWithRange:(NSRange)range;
(1)发送POST请求步骤spa
a.肯定URL路径 b.建立请求对象(可变对象) c.修改请求对象的方法为POST,设置请求体(Data) d.发送一个异步请求 e.补充:设置请求超时,处理错误信息,设置请求头(如获取客户端的版本等等,请求头是可设置可不设置的)
(2)相关代码线程
//1.肯定请求路径 NSURL *url = [NSURL URLWithString:@"http://120.25.226.186:32812/login"]; //2.建立请求对象 NSMutableURLRequest *request = [NSMutableURLRequest requestWithURL:url]; //2.1更改请求方法 request.HTTPMethod = @"POST"; //2.2设置请求体 request.HTTPBody = [@"username=520it&pwd=520it" dataUsingEncoding:NSUTF8StringEncoding]; //2.3请求超时 request.timeoutInterval = 5; //2.4设置请求头 [request setValue:@"ios 9.0" forHTTPHeaderField:@"User-Agent"]; //3.发送请求 [NSURLConnection sendAsynchronousRequest:request queue:[NSOperationQueue mainQueue] completionHandler:^(NSURLResponse * __nullable response, NSData * __nullable data, NSError * __nullable connectionError) { //4.解析服务器返回的数据 if (connectionError) { NSLog(@"--请求失败-"); }else { NSLog(@"%@",[[NSString alloc]initWithData:data encoding:NSUTF8StringEncoding]); } }];
1.使用主线程发送:
代理方法一:
代理方法二:
1.使用子线程发送:(考虑到下载耗时)
代理方法一:
代理方法二:
注意点:代理方法一和方法二之间的区别就是代理方法是否立刻发送请求.
1)若没有设置,则默认的是立刻发送请求,可是问题来了,子线程并不会开启?
解决方案:手动开启子线程的RunLoop
[[NSRunLoop currentRunLoop] run];
2)如有设置,且设置为NO,那么咱们就得手动去发送请求:
[connect start];
//该方法内部会自动将当前的请求对象添加到runloop中,指定运行模式为默认
//若是子线程对应的runloop没有建立,那么会自动建立