objective-c – iOS 5:https(ASIHTTPRequest)停止工作

前端之家收集整理的这篇文章主要介绍了objective-c – iOS 5:https(ASIHTTPRequest)停止工作前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个使用ASIHTTPRequest的应用程序. @H_301_2@我用iOS 5(sdk:5.0 / xcode:4.2 Build 4D199)重新编译我的应用程序,https连接失败并显示错误消息(与禁用https相同的调用正常):

Error Domain=ASIHTTPRequestErrorDomain Code=1 "A connection failure occurred" UserInfo=0xa8e66e0 {NSUnderlyingError=0xa8ac6c0 "The operation couldn’t be completed. (OSStatus error -9844.)",NSLocalizedDescription=A connection failure occurred}
@H_301_2@启用调试日志:

[STATUS] Starting asynchronous request <ASIFormDataRequest: 0xd96fc00>

[CONNECTION] Request <ASIFormDataRequest: 0xd96fc00> will not use a persistent connection

[STATUS] Request <ASIFormDataRequest: 0xd96fc00>: Failed

[CONNECTION] Request #(null) Failed and will invalidate connection #(null)
@H_301_2@我发现这个相关帖子:
https://devforums.apple.com/message/537440#537440
这可以解释我的问题.

@H_301_2@基于iOS 5喜欢TLS 1.2的想法,我尝试在AIHTTPRequest.m中更改设置kcfStreamSocketSecurityLevelTLSv1

NSDictionary *sslProperties = [[NSDictionary alloc] initWithObjectsAndKeys:
                                     [NSNumber numberWithBool:YES],kcfStreamSSLAllowsExpiredCertificates,[NSNumber numberWithBool:YES],kcfStreamSSLAllowsAnyRoot,[NSNumber numberWithBool:NO],kcfStreamSSLValidatesCertificateChain,kcfNull,kcfStreamSSLPeerName,kcfStreamSocketSecurityLevelTLSv1,kcfStreamSSLLevel,// my modif
                                     nil];
@H_301_2@没有成功.也许我的修改是不正确的?

@H_301_2@细节:

@H_301_2@>我的ARC被禁用了
>我使用libz.1.2.5.dylib
>一周前我更新了ASIHTTPRequest.

@H_301_2@我不知道问题是证书故事(如TLS版本)还是其他内容.

@H_301_2@任何帮助/想法是欢迎!

解决方法

这是最终的解决方案: @H_301_2@https://developer.apple.com/library/ios/#technotes/tn2287/_index.html#//apple_ref/doc/uid/DTS40011309

NSDictionary *sslProperties = [[NSDictionary alloc] initWithObjectsAndKeys:
                                       [NSNumber numberWithBool:YES],@"kcfStreamSocketSecurityLevelTLSv1_0SSLv3",nil];
@H_301_2@添加此参数:

@"kcfStreamSocketSecurityLevelTLSv1_0SSLv3",

猜你在找的C&C++相关文章