这个问题在这里已经有了答案:
How to use NSURLConnection to connect with SSL for an untrusted cert?
(13 个回答)
去年关闭。
我正在使用以下代码将用户登录信息发送到服务器,但 Apple 表示我正在使用私有(private) API 并将拒绝该应用程序。我该如何解决这个问题?
将替换为 [NSURLRequest setAllowsAnyHTTPSCertificate:YES forHost:[url host]];
[request setHTTPMethod:@"POST"];
足够?
@interface NSURLRequest (DummyInterface)
+ (BOOL)allowsAnyHTTPSCertificateForHost:(NSString*)host;
+ (void)setAllowsAnyHTTPSCertificate:(BOOL)allow forHost:(NSString*)host;
@end
和我的登录代码:
// token url
NSURL *url=[NSURL URLWithString:@"http://xxxxxxxx.com/api/token"];
NSData *postData = [post dataUsingEncoding:NSASCIIStringEncoding allowLossyConversion:YES];
NSString *postLength = [NSString stringWithFormat:@"%d", [postData length]];
NSMutableURLRequest *request = [[NSMutableURLRequest alloc] init];
[request setURL:url];
[request setHTTPMethod:@"POST"];
[request setValue:postLength forHTTPHeaderField:@"Content-Length"];
[request setValue:@"application/json" forHTTPHeaderField:@"Accept"];
[request setValue:@"application/x-www-form-urlencoded" forHTTPHeaderField:@"Content-Type"];
[request setHTTPBody:postData];
NSLog(@"url is %@",url),
NSLog(@"request is %@",request),
**[NSURLRequest setAllowsAnyHTTPSCertificate:YES forHost:[url host]];**
最佳答案
似乎有一个公共(public)API。
How to use NSURLConnection to connect with SSL for an untrusted cert?
必须迟到但可能会有所帮助。
关于ios - 如何修复用于 Apple 应用提交的 setAllowsAnyHTTPSCertificate 私有(private) api?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19276373/