我的支票支付密码怎么填写忘记了然后填写这个不知道怎么弄

IOS----轻松掌握AFN网络顶级框架
一、什么是AFN
全称是AFNetworking,是对NSURLConnection的一层封装
虽然运行效率没有ASI高,但是使用比ASI简单
在iOS开发中,使用比较广泛
二、AFN结构
NSURLConnection
AFURLConnectionOperation
AFHTTPRequestOperation
AFHTTPRequestOperationManager(封装了常用的 HTTP 方法)
baseURL :AFN建议开发者针对 AFHTTPRequestOperationManager 自定义个一个单例子类,设置 baseURL, 所有的网络访问,都只使用相对路径即可
requestSerializer :请求数据格式/默认是二进制的 HTTP
responseSerializer :响应的数据格式/默认是 JSON 格式
operationQueue
reachabilityManager :网络连接管理器
manager :方便创建管理器的类方法
HTTPRequestOperationWithRequest :在访问服务器时,如果要告诉服务器一些附加信息,都需要在 Request 中设置
NSURLSession
AFURLSessionManager
AFHTTPSessionManager(封装了常用的 HTTP 方法)
UIKit + AFNetworking 分类
NSProgress :利用KVO
半自动的序列化&反序列化的功能
AFURLRequestSerialization :请求的数据格式/默认是二进制的
AFURLResponseSerialization :响应的数据格式/默认是JSON格式
AFSecurityPolicy
对苹果的网络连接检测做了一个封装
AFNetworkReachabilityManager
三、AFN基本使用
1.AFHTTPSessionManager
是AFN中最重要的对象之一
封装了HTTP请求的常见处理
GET\POST请求
解析服务器的响应数据
创建AFHTTPSessionManager
AFHTTPSessionManager *mgr = [AFHTTPSessionManager manager];
AFHTTPSessionManager的GET\POST请求
// GET请求
& & &http://120.25.226.186:32812/login?username=520it&pwd=520it
& & &第一个参数: 请求的地址 &http://120.25.226.186:32812/login
& & &第二个参数: 请求的参数 &username=520it&pwd=520it
& & &第三个参数: 请求成功的回调
& & &第四个参数: 请求失败的回调
& & &只要利用AFN发送请求, 如果服务器返回的是JSON数据, 那么AFN会自动将JSON转会成OC对象返回给我们
- (NSURLSessionDataTask *)GET:(NSString *)URLString
& & & & & & & & & &parameters:(id)parameters
& & & & & & & & & &success:(void (^)(NSURLSessionDataTask *task, id responseObject))success
& & & & & & & & & &failure:(void (^)(NSURLSessionDataTask *task, NSError *error))failure
// POST请求
- (NSURLSessionDataTask *)POST:(NSString *)URLString
& & & & & & & & & &parameters:(id)parameters
& & & & & & & & & &success:(void (^)(NSURLSessionDataTask *task, id responseObject))success
& & & & & & & & & &failure:(void (^)(NSURLSessionDataTask *task, NSError *error))failure
- (void)get2
// 1.创建AFN管理者
AFHTTPSessionManager *manager = [AFHTTPSessionManager manager];
// 2.利用AFN管理者发送请求
NSDictionary *params = @{
@&username& : @&520it&,
@&pwd& : @&520it&
[manager GET:@&http://120.25.226.186:32812/login& parameters:params success:^(NSURLSessionDataTask *task, id responseObject) {
NSLog(@&请求成功---%@&, responseObject);
} failure:^(NSURLSessionDataTask *task, NSError *error) {
NSLog(@&请求失败---%@&, error);
- (void)post2
// 1.创建AFN管理者
AFHTTPSessionManager *manager = [AFHTTPSessionManager manager];
// 2.利用AFN管理者发送请求
NSDictionary *params = @{
@&username& : @&520it&,
@&pwd& : @&520it&
[manager POST:@&http://120.25.226.186:32812/login& parameters:params success:^(NSURLSessionDataTask *task, id responseObject) {
NSLog(@&请求成功---%@&, responseObject);
} failure:^(NSURLSessionDataTask *task, NSError *error) {
NSLog(@&请求失败---%@&, error);
2.AFHTTPRequestOperationManager
创建AFHTTPRequestOperationManager
// 1.创建AFN管理者
// AFHTTPRequestOperationManager内部包装了NSURLConnection
AFHTTPRequestOperationManager *manager = [AFHTTPRequestOperationManager manager];
AFHTTPRequestOperationManager的GET\POST请求
- (NSURLSessionDataTask *)GET:(NSString *)URLString
parameters:(id)parameters
success:(void (^)(NSURLSessionDataTask *task, id responseObject))success
failure:(void (^)(NSURLSessionDataTask *task, NSError *error))failure
// POST请求
- (NSURLSessionDataTask *)POST:(NSString *)URLString
parameters:(id)parameters
success:(void (^)(NSURLSessionDataTask *task, id responseObject))success
failure:(void (^)(NSURLSessionDataTask *task, NSError *error))failure
- (void)get
// 1.创建AFN管理者
// AFHTTPRequestOperationManager内部包装了NSURLConnection
AFHTTPRequestOperationManager *manager = [AFHTTPRequestOperationManager manager];
// 2.利用AFN管理者发送请求
NSDictionary *params = @{
@&username& : @&520it&,
@&pwd& : @&520it&
[manager GET:@&http://120.25.226.186:32812/login& parameters:params success:^(AFHTTPRequestOperation *operation, id responseObject) {
NSLog(@&请求成功---%@&, responseObject);
} failure:^(AFHTTPRequestOperation *operation, NSError *error) {
NSLog(@&请求失败---%@&, error);
- (void)post
// 1.创建AFN管理者
// AFHTTPRequestOperationManager内部包装了NSURLConnection
AFHTTPRequestOperationManager *manager = [AFHTTPRequestOperationManager manager];
// 2.利用AFN管理者发送请求
NSDictionary *params = @{
@&username& : @&520it&,
@&pwd& : @&520it&
[manager POST:@&http://120.25.226.186:32812/login& parameters:params success:^(AFHTTPRequestOperation *operation, id responseObject) {
NSLog(@&请求成功---%@&, responseObject);
} failure:^(AFHTTPRequestOperation *operation, NSError *error) {
NSLog(@&请求失败---%@&, error);
四、AFN文件下载
// 执行下载文件的方法,可以监控下载进度
- (void)downLoadMonitor
// 1.创建网络管理者
// AFHTTPSessionManager 基于NSURLSession
AFHTTPSessionManager *manager = [AFHTTPSessionManager manager];
// 2.利用网络管理者下载数据
NSURLRequest *request = [NSURLRequest requestWithURL:[NSURL URLWithString:@&http://120.25.226.186:32812/resources/videos/minion_02.mp4&]];
destination
- targetPath: 给我们自动写入的文件路径
- block的返回值, 要求返回一个URL, 返回的这个URL就是剪切的位置的路径
completionHandler
- url :destination返回的URL == block的返回的路径
@property int64_t totalUnitC
需要下载文件的总大小
@property int64_t completedUnitC 当前已经下载的大小
NSProgress *progress =
NSURLSessionDownloadTask *downTask = [manager downloadTaskWithRequest:request progress:&progress destination:^NSURL *(NSURL *targetPath, NSURLResponse *response) {
NSString *cachesPath = [NSSearchPathForDirectoriesInDomains(NSCachesDirectory, NSUserDomainMask, YES) lastObject];
NSString *path = [cachesPath stringByAppendingPathComponent:response.suggestedFilename];
return [NSURL fileURLWithPath:path];
} completionHandler:^(NSURLResponse *response, NSURL *filePath, NSError *error) {
NSLog(@&%@&,filePath.absoluteString);
要跟踪进度,需要使用 NSProgress,是在 iOS 7.0 推出的,专门用来跟踪进度的类!
NSProgress只是一个对象!如何跟踪进度!-& KVO 对属性变化的监听!
@property int64_t totalUnitC
@property int64_t completedUnitC
完成单位数
// 给Progress添加监听 KVO
[progress addObserver:self forKeyPath:@&completedUnitCount& options:NSKeyValueObservingOptionNew context:nil];
// 3.启动任务
[downTask resume];
// 收到通知调用的方法
- (void)observeValueForKeyPath:(NSString *)keyPath ofObject:(NSProgress *)object change:(NSDictionary *)change context:(void *)context
NSLog(@&%f&,1.0 * pletedUnitCount / object.totalUnitCount);
// 回到主队列刷新UI
dispatch_async(dispatch_get_main_queue(), ^{
self.progress.progress = 1.0 * pletedUnitCount / object.totalUnitC
五、AFN序列化
默认是JSON数据,接收类型是JSON
如果接收的类型和返回的类型不匹配会报错
// 1.创建AFN管理者
AFHTTPSessionManager *manager = [AFHTTPSessionManager manager];
// 默认请求二进制
// 默认响应是JSON
// 告诉AFN,支持接受 text/xml 的数据
// [AFJSONResponseSerializer serializer].acceptableContentTypes = [NSSet setWithObject:@&text/xml&];
// 告诉AFN如何解析数据
// 告诉AFN客户端, 将返回的数据当做JSON来处理,默认的是以JSON处理
manager.responseSerializer = [AFJSONResponseSerializer serializer];
// 告诉AFN客户端, 将返回的数据当做XML来处理
manager.responseSerializer = [AFXMLParserResponseSerializer serializer];
// 告诉AFN客户端, 将返回的数据当做而进行来数据 (服务器返回什么就是什么)
manager.responseSerializer = [AFHTTPResponseSerializer serializer];
六、AFN文件上传
// formData: 专门用于拼接需要上传的数据
- (NSURLSessionDataTask *)POST:(NSString *)URLString
parameters:(id)parameters
constructingBodyWithBlock:(void (^)(id &AFMultipartFormData& formData))block
success:(void (^)(NSURLSessionDataTask *task, id responseObject))success
failure:(void (^)(NSURLSessionDataTask *task, NSError *error))failure
AFN上传文件代码示例
// 1.创建网络管理者
AFHTTPSessionManager *manager = [AFHTTPSessionManager manager];
// 2.利用网络管理者上传数据
NSDictionary *dict = @{@&username&:@&Syl&};
// formData: 专门用于拼接需要上传的数据
[manager POST:@&http://120.25.226.186:32812/upload& parameters:dict constructingBodyWithBlock:
^void(id&AFMultipartFormData& formData) {
Data: 需要上传的数据
name: 服务器参数的名称
fileName: 文件名称
mimeType: 文件的类型
UIImage *image =[UIImage imageNamed:@&minion_02&];
NSData *data = UIImagePNGRepresentation(image);
[formData appendPartWithFileData:data name:@&file& fileName:@&abc.png& mimeType:@&image/png&];
NSURL *url = [NSURL fileURLWithPath:@&/Users/apple/Desktop/CertificateSigningRequest.certSigningRequest&];
// 任意的二进制数据MIMEType application/octet-stream
// [formData appendPartWithFileURL:url name:@&file& fileName:@&abc.cer& mimeType:@&application/octet-stream& error:nil];
[formData appendPartWithFileURL:url name:@&file& error:nil];
} success:^void(NSURLSessionDataTask * task, id responseObject) {
// 请求成功
NSLog(@&请求成功 %@&, responseObject);
} failure:^void(NSURLSessionDataTask * task, NSError * error) {
// 请求失败
NSLog(@&请求失败 %@&, error);
七、监控联网状态
1.AFN监控联网状态
联网状态status
// 2.设置监听
AFNetworkReachabilityStatusUnknown
AFNetworkReachabilityStatusNotReachable
AFNetworkReachabilityStatusReachableViaWWAN = 1,
AFNetworkReachabilityStatusReachableViaWiFi = 2,
AFNetworkReachabilityManager *manager = [AFNetworkReachabilityManager sharedManager];
// 提示:要监控网络连接状态,必须要先调用单例的startMonitoring方法
[manager startMonitoring];
[manager setReachabilityStatusChangeBlock:^(AFNetworkReachabilityStatus status) {
NSLog(@&%d&, status);
2.Reachability监控联网状态苹果提供,导入这两个类使用
// 1.检测wifi状态
Reachability *wifi = [Reachability reachabilityForLocalWiFi];
// 2.检测手机是否能上网络(WIFI\3G\2.5G)
Reachability *conn = [Reachability reachabilityForInternetConnection];
// 3.判断网络状态
if ([wifi currentReachabilityStatus] != NotReachable) { // 有wifi
NSLog(@&有wifi&);
} else if ([conn currentReachabilityStatus] != NotReachable) { // 没有使用wifi, 使用手机自带网络进行上网
NSLog(@&使用手机自带网络进行上网&);
} else { // 没有网络
NSLog(@&没有网络&);
①判断联网状态
// [wifi currentReachabilityStatus] != NotReachable
// [conn currentReachabilityStatus] != NotReachable
// 没有用WIFI, 只用了手机网络
// [wifi currentReachabilityStatus] == NotReachable
// [conn currentReachabilityStatus] != NotReachable
// 没有网络
// [wifi currentReachabilityStatus] == NotReachable
// [conn currentReachabilityStatus] == NotReachable
②实时监听网络状态
#import &ViewController.h&
#import &Reachability.h&
@interface HMViewController ()
@property (nonatomic, strong) Reachability *
@implementation HMViewController
- (void)viewDidLoad
[super viewDidLoad];
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(checkNetworkState) name:kReachabilityChangedNotification object:nil];
self.conn = [Reachability reachabilityForInternetConnection];
[self.conn startNotifier];
- (void)dealloc
[self.conn stopNotifier];
[[NSNotificationCenter defaultCenter] removeObserver:self];
- (void)checkNetworkState
// 1.检测wifi状态
Reachability *wifi = [Reachability reachabilityForLocalWiFi];
// 2.检测手机是否能上网络(WIFI\3G\2.5G)
Reachability *conn = [Reachability reachabilityForInternetConnection];
// 3.判断网络状态
if ([wifi currentReachabilityStatus] != NotReachable) { // 有wifi
NSLog(@&有wifi&);
} else if ([conn currentReachabilityStatus] != NotReachable) { // 没有使用wifi, 使用手机自带网络进行上网
NSLog(@&使用手机自带网络进行上网&);
} else { // 没有网络
NSLog(@&没有网络&);
(window.slotbydup=window.slotbydup || []).push({
id: '2467140',
container: s,
size: '1000,90',
display: 'inlay-fix'
(window.slotbydup=window.slotbydup || []).push({
id: '2467141',
container: s,
size: '1000,90',
display: 'inlay-fix'
(window.slotbydup=window.slotbydup || []).push({
id: '2467142',
container: s,
size: '1000,90',
display: 'inlay-fix'
(window.slotbydup=window.slotbydup || []).push({
id: '2467143',
container: s,
size: '1000,90',
display: 'inlay-fix'
(window.slotbydup=window.slotbydup || []).push({
id: '2467148',
container: s,
size: '1000,90',
display: 'inlay-fix'afnetworking3.0如何保证前一次请求返回数据之后再发送下一次请求_问答_ThinkSAAS
afnetworking3.0如何保证前一次请求返回数据之后再发送下一次请求
afnetworking3.0如何保证前一次请求返回数据之后再发送下一次请求
利用AFN3.0进行网络请求,要发送的参数在一个数组里,每次取数组中的一条数据设置参数发送请求,
我通过for循环遍历数组并设置参数发送请求,将网络请求返回的数据添加到一个新的数组中,
发现不是每次请求返回的数据的顺序是一样的,功能需求返回数据的排序必须跟发送请求的顺序是一样的,
求问有什么方法保证前一次请求返回数据之后再发送下一次请求?
非常感谢,万分感谢!!!!
按你的做法当然不一定一样了,有些请求可能是后发出的,但返回比较快,就先返回了。
不清楚你的需求是不是一定要依次请求。比如像一次上传 10 张图片,然后把返回的 url 按顺序塞到一个数组里这种需求,我们一般都是分几个线程同时请求的,而不是一张一张依次传的。这样要快很多。
如果你是要保证依次请求的话,就要把下一次请求的发送放在上一次请求结束之后。比如:
- (void)requestWithArray:(NSArray*)array index:(NSInteger)index completion:(SomeBlock)completion {
if (index &= array.count) {
if (completion) {
completion();
AFHTTPRequestOperationManager* manager = [self httpsRequestManager];
NSDictionary* params = @{"key":array[index]};
__weak typeof(self) weakSelf =
[manager GET:url parameters:params success:^(AFHTTPRequestOperation *operation, id responseObject) {
[weakSelf requestWithArray:array index:index + 1 completion:completion];
} failure:^(AFHTTPRequestOperation *operation, NSError *error) {
// handle failure
大概是这意思,明白了吗?
但是像上传 10 张图片那种,就是只要保证结果顺序正确,不需要请求一个一个串行的话,应该用[AFURLConnectionOperation batchOfRequestOperations:]。最好优先考虑下这样是否能满足你的需求。
你的问题类似这个如果你只是希望保证返回结果的顺序,就并不一定需要所有的请求串行的进行。
另外,如果你非要串行的进行请求的话,可以新建一个 NSOperationQueue,并把它的 maxConcurrentOperationCount 设置为 1, 然后把你的每个请求顺序地加入到这个 NSOperationQueue 里去。
添加你想要问的问题
PHP开发框架
开发工具/编程工具
服务器环境
ThinkSAAS商业授权:
ThinkSAAS为用户提供有偿个性定制开发服务
ThinkSAAS将为商业授权用户提供二次开发指导和技术支持
让ThinkSAAS更好,把建议拿来。
开发客服微信iOS开发网络数据之AFNetworking使用
http网络库是集XML解析,Json解析,网络图片下载,plist解析,数据流请求操作,上传,下载,缓存等网络众多功能于一身的强大的类库。最新版本支持session,xctool单元测试。网络获取数据一直是手机软件的重中之重,如果处理的不好,会造成很差的用户体验。随着ASIHTTPRequest的停止更新,更换网络库是必然的事情,AFNetworking就是很好的替代品。而且都是轻量级,不要担心加入太多库会多软件性能有影响。
1.为什么用第三方网络库?先说如果不用网络库,我曾有一次觉得什么都用苹果原生的好,XML解析用苹果自带的委托,下载图片自己写,如果你也有跟我一样的经历,那你会发现自己管理起来很复杂,很容易出错。而且性能不好。如果你是一个追求完美的人,那就放下你的固执,就如当初的我一样,尝试一下网络库吧。
2.为什么要用AFNetworking?第一点,它有人更新和维护,而且目前使用者很多,第二点,还是使用者很多,那么他的资料,文档,demo就多,很好找遇到问题好解决。如果不用AFNetworking,还有一种MKNetworkKit也不错,不妨一试。
如何选择AFNetworking版本
首先得下载AFNetworking库文件,下载时得首先弄清楚,你将要开发的软件兼容的最低版本是多少。AFNetworking
2.0或者之后的版本需要xcode5.0版本并且只能为IOS6或更高的手机系统上运行,如果开发MAC程序,那么2.0版本只能在MAC
OS X 10.8或者更高的版本上运行。
如果你想要兼容IOS5或MAC OS X 10.7,那你需要用最新发布的1.x版本
如果要兼容4.3或者MAC OS X 10.6,需要用最新发布的0.10.x版本
AFNetworking 0.10.x
2013年大多数软件兼容的最低版本为4.3,而2014年,估计大多数软件兼容的最低版本将会是5.0甚至6.0;
所以,目前最好的选择还是1.x版本,兼容到IOS5.0。
如何通过URL获取json数据
第一种,利用AFJSONRequestOperation,官方网站上给的例子:
NSString *str=[NSString stringWithFormat:@"https://alpha-api.app.net/stream/0/posts/stream/global"];
& NSURL *url =
[NSURL URLWithString:[str
stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding]];
& NSURLRequest *request = [NSURLRequest
requestWithURL:url];
从URL获取json数据
& AFJSONRequestOperation *operation1 = [AFJSONRequestOperation
JSONRequestOperationWithRequest:request success:^(NSURLRequest *request, NSHTTPURLResponse *response, NSDictionary* JSON) {
& & NSLog(@"获取到的数据为:%@",JSON);
& & } failure:^(NSURLRequest *request, NSHTTPURLResponse *response, NSError *error, id data) {
& NSLog(@"发生错误!%@",error);
& & [operation1 start];
第二种方法,利用AFHTTPRequestOperation&先获取到字符串形式的数据,然后转换成json格式,将NSString格式的数据转换成json数据,利用IOS5自带的json解析方法:
& &NSString&*str=[NSString&stringWithFormat:@"https://alpha-api.app.net/stream/0/posts/stream/global"];
&&NSURL&*url =
[NSURL&URLWithString:[str&stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding]];
&&NSURLRequest&*request =
[NSURLRequest&requestWithURL:url];
&AFHTTPRequestOperation
*operation =
[[AFHTTPRequestOperation
alloc] initWithRequest:request];
[operation setCompletionBlockWithSuccess:^(AFHTTPRequestOperation *operation, id responseObject) {
& NSString
*html = operation.responseString;
& &NSData* data=[html dataUsingEncoding:NSUTF8StringEncoding];
& &id dict=[NSJSONSerialization&
JSONObjectWithData:data
options:0 error:nil];
& NSLog(@"获取到的数据为:%@",dict);
}failure:^(AFHTTPRequestOperation *operation, NSError *error) {
& NSLog(@"发生错误!%@",error);
& NSOperationQueue *queue = [[NSOperationQueue
alloc] init];
& & [queue addOperation:operation];
如果发生Error Domain=NSURLErrorDomain Code=-1000 "bad URL"
UserInfo=0x14defc80 {NSUnderlyingError=0x14deea10 "bad URL",
NSLocalizedDescription=bad URL这个错误,请检查URL编码格式。有没有进行stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding
如何通过URL获取图片
异步获取图片,通过队列实现,而且图片会有缓存,在下次请求相同的链接时,系统会自动调用缓存,而不从网上请求数据。
UIImageView *imageView = [[UIImageView alloc] initWithFrame:CGRectMake(0.0f, 100.0f, 100.0f, 100.0f)];
& & [imageView setImageWithURL:[NSURL URLWithString:@"http://i./r4uwx.jpg"] placeholderImage:[UIImage imageNamed:@"placeholder-avatar"]];
& & [self.view addSubview:imageView];
上面的方法是官方提供的,还有一种方法,
NSURLRequest *request = [NSURLRequest requestWithURL:[NSURL
URLWithString:@"http://www./wp-content/uploads/2013/01/scene.png"]];
& AFImageRequestOperation *operation = [AFImageRequestOperation
imageRequestOperationWithRequest:request imageProcessingBlock:nil
success:^(NSURLRequest
*request, NSHTTPURLResponse
*response, UIImage *image) {
& self.backgroundImageView.image =
} failure:^(NSURLRequest
*request, NSHTTPURLResponse
*response, NSError *error) {
& NSLog(@"Error
%@",error);
& & [operation start];
如果使用第一种URLWithString:&&placeholderImage:会有更多的细节处理,其实实现还是通过AFImageRequestOperation处理,可以点击URLWithString:&&placeholderImage:方法进去看一下就一目了然了。所以我觉得还是用第一种好。
如何通过URL获取plist文件
通过url获取plist文件的内容,用的很少,这个方法在官方提供的方法里面没有
NSString *weatherUrl =
@".cn/buick/kls/Buickhousekeeper.plist";
& NSURL *url =
[NSURL URLWithString:[weatherUrl
stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding]];
& NSURLRequest *request = [NSURLRequest
requestWithURL:url];
[AFPropertyListRequestOperation
addAcceptableContentTypes:[NSSet setWithObject:@"text/plain"]];
& AFPropertyListRequestOperation
*operation =
[AFPropertyListRequestOperation
propertyListRequestOperationWithRequest:request success:^(NSURLRequest *request, NSHTTPURLResponse *response, id propertyList) {
& NSLog(@"%@",(NSDictionary *)propertyList);
& & }failure:^(NSURLRequest *request, NSHTTPURLResponse *response, NSError *error, id propertyList) {
& NSLog(@"%@",error);
& & [operation start];
如果稍不留神,可能就出现Error
Domain=AFNetworkingErrorDomain Code=-1016 "Expected content type
& "application/x-plist"
)}, got text/plain"
UserInfo=0x16e91ce0 {NSLocalizedRecoverySuggestion=
AFNetworkingOperationFailingURLRequestErrorKey= { },
NSErrorFailingURLKey=, NSLocalizedDescription=Expected content type
& "application/x-plist"
)}, got text/plain,
AFNetworkingOperationFailinponseErrorKey= { URL:
&} { status code: 200, headers {
& "Accept-Ranges" =
& Connection = "keep-alive";
& "Content-Length" = 974;
& "Content-Type" = "text/plain";
& Date = "Sat, 25 Jan :26
""ce-4ee63e1c80e00"";
& "Last-Modified" = "Wed, 25 Dec :24
& Server = "nginx/1.4.2";
可能还会出现乱码,解决办法就是[AFPropertyListRequestOperation&addAcceptableContentTypes:[NSSet&setWithObject:@"text/plain"]];
如何通过URL获取XML数据
xml解析使用AFXMLRequestOperation,需要实现苹果自带的NSXMLParserDelegate委托方法,XML中有一些不需要的协议格式内容,所以就不能像json那样解析,还得实现委托。我之前有想过能否所有的XML链接用一个类处理,而且跟服务端做了沟通,结果很不方便,效果不好。XML大多标签不同,格式也不固定,所以就有问题,使用json就要方便的多。
第一步;在.h文件中加入委托NSXMLParserDelegate
第二步;在.m文件方法中加入代码
*url = [NSURL
URLWithString:@"http://113.106.90.22:5244/sshopinfo"];
& NSURLRequest *request = [NSURLRequest
requestWithURL:url];
& AFXMLRequestOperation *operation =
[AFXMLRequestOperation
XMLParserRequestOperationWithRequest:request success:^(NSURLRequest *request, NSHTTPURLResponse *response, NSXMLParser *XMLParser) {
& XMLParser.delegate = self;
& & [XMLParser
setShouldProcessNamespaces:YES];
& [XMLParser parse];
& & }failure:^(NSURLRequest *request, NSHTTPURLResponse *response, NSError *error, NSXMLParser *XMLParser) {
& NSLog(@"%@",error);
& & [operation start];
第三步;在.m文件中实现委托方法
&&//在文档开始的时候触发
-(void)parserDidStartDocument:(NSXMLParser *)parser{
& NSLog(@"解析开始!");
//解析起始标记
- (void)parser:(NSXMLParser *)parser
didStartElement:(NSString
*)elementName namespaceURI:(NSString *)namespaceURI
qualifiedName:(NSString *)qName
attributes:(NSDictionary
*)attributeDict{
& & NSLog(@"标记:%@",elementName);
//解析文本节点
- (void)parser:(NSXMLParser *)parser
foundCharacters:(NSString
& & NSLog(@"值:%@",string);
//解析结束标记
- (void)parser:(NSXMLParser *)parser
didEndElement:(NSString
*)elementName namespaceURI:(NSString *)namespaceURI
qualifiedName:(NSString
& & NSLog(@"结束标记:%@",elementName);
//文档结束时触发
parserDidEndDocument:(NSXMLParser *)parser{
& NSLog(@"解析结束!");
运行的结果:
如何使用AFHTTPClient进行web service操作
AFHTTPClient处理GET 和
POST请求.做网页的朋友们这个方法用的比较多。在要经常调用某个请求时,可以封装,节省资源。
&BaseURLString&=
@"/downloads/weather_sample/";
*baseURL = [NSURL
URLWithString:[NSString
stringWithFormat:BaseURLString]];
& NSDictionary *parameters = [NSDictionary
dictionaryWithObject:@"json" forKey:@"format"];
& AFHTTPClient *client = [[AFHTTPClient alloc] initWithBaseURL:baseURL];
[client registerHTTPOperationClass:[AFJSONRequestOperation class]];
[client setDefaultHeader:@"Accept" value:@"text/html"];
& & [client postPath:@"weather.php" parameters:parameters success:^(AFHTTPRequestOperation *operation,
id responseObject) {
& & NSString* newStr = [[NSString alloc] initWithData:responseObject encoding:NSUTF8StringEncoding];
& NSLog(@"POST请求:%@",newStr);
}failure:^(AFHTTPRequestOperation *operation, NSError *error) {
& NSLog(@"%@",error);
& & [client getPath:@"weather.php" parameters:parameters success:^(AFHTTPRequestOperation *operation,
id responseObject) {
& & NSString* newStr = [[NSString alloc] initWithData:responseObject encoding:NSUTF8StringEncoding];
& NSLog(@"GET请求:%@",newStr);
}failure:^(AFHTTPRequestOperation *operation, NSError *error) {
& NSLog(@"%@",error);
运行结果:
如果需要显示网络活动指示器,可以用下面方法:
[AFNetworkActivityIndicatorManager sharedManager].enabled =
Error: Error Domain=AFNetworkingErrorDomain Code=-1016
"Request failed: unacceptable content-type: text/html"
UserInfo=0x16774de0
{NSErrorFailingURLKey=http://192.168.2.2:8181/ecar/tsp/uploadLocation?CID=781666&serviceType=1,
AFNetworkingOperationFailinponseErrorKey= { URL:
http://192.168.2.2:8181/ecar/tsp/uploadLocation?CID=781666&serviceType=1
} { status code: 200, headers {
} }, NSLocalizedDescription=Request failed: unacceptable
content-type: text/html}
返回数据格式不对。注销这句话:&op.responseSerializer
= [AFJSONResponseSerializer serializer];然后将返回的数据自己转换。
error = Error Domain=com.alamofire.error.serialization.response
Code=-1016 "Request failed: unacceptable content-type: text/html"
UserInfo=0x
{com.alamofire.serialization.response.error.response= { URL:
http://192.168.5.132/api/cats?type=apps } { status code: 200,
& & Connection =
"keep-alive";
& & "Content-Type" = "text/
charset=utf-8";
& & Date = "Thu, 05 Nov 2015
10:27:42 GMT";
& & Server =
& & "Transfer-Encoding" =
AF可以接受json以外的数据 & &自己随意定义的格式都可以
& &只不过要使用AFNetwork提供的解析方法的话
& 它只对通用的格式做处理 &
&你返回的数据不是那种格式 & 他就无法解析出来
& & 那要你自己处理 &
&改变AFNetWork的库文件 &
& 找到他判断错误的那个函数 &
&让他从正确的方法返回 & &
如果你不会的话 &就在返回错误的方法处理也可以 &
反正数据已经到了 & & &
网络的目的 & 是为了得到数据 &
&你的数据已经到了 &
只不过AFNetwork认定你的数据不符合常用的格式 & &
&确实也不符合 & 因为你的数据是加密的东西
& 而且是对整个json格式加密 & 而不是只对值加密
& &所以要实现这种格式的传输
& &只能修改AFNetwork的库
& &而你不会 &
&那就先这么用着
举个例子 & &你们现在的做法是对整个字符串加密
& &如果你不这么做 &
&只将值部分加密 &而不对键加密
& &就是{“message”:“值的密文”}
& 那么这个数据仍然符合json格式 &
AFNetwork依然能解析出来 & &
& 你们对整个json字符串都加密了 &那密文就不是json格式了
所以你们可以按我说的改 &仅加密值部分 &
& 也就按照现在的方法 &
&在错误的返回方法里面处理数据 &
&但是你自己知道数据是正确的 &
只不过AFNetwork误判了而已 & &
& &这个属于原理上东西 &
&改不了 & &
要么就是不让AFNetwork解析 & &
&他只透传 & &你自己解析
& &如果让他帮你解析 &
你就要指定一个格式给他 & &指定了格式
&而你的数据不符合格式 & 那就是按错误的方法返回
AFNetworking关于HTTP认证的问题
AFNetwork实现basic认证的方法很简单
AFNetwork实现digest认证
创建一个NSURLCredential对象,然后将对象赋值到请求
AFHTTPRequestOperationManager *manager = [AFHTTPRequestOperationManager manager];
NSURLCredential *credential = [[NSURLCredential alloc] initWithUser:@"Username" password:@"Password" persistence:NSURLCredentialPersistenceForSession];
[manager setCredential:credential];&
。关于AFNetWork2.0的demo已经完成,有需要的朋友到QQ群:
已投稿到:
以上网友发言只代表其个人观点,不代表新浪网的观点或立场。

我要回帖

更多关于 支票密码怎么填写 的文章

 

随机推荐