无法信任iphone上的自签名证书

Zac*_*ton 7 iphone ssl https cocoa-touch objective-c

我目前正在尝试使用自签名证书连接到服务器.我正在使用NSURLConnection连接到服务器.如何确保我只信任正确的服务器并取消所有其他连接?我使用以下代码

- (void)connection:(NSURLConnection *)connection didReceiveAuthenticationChallenge:(NSURLAuthenticationChallenge *)challenge {  

    SecTrustResultType results;
    SecTrustRef trust = [[challenge protectionSpace] serverTrust];

    SecTrustEvaluate(trust, &results);

    if (results == kSecTrustResultProceed || results == kSecTrustResultConfirm) {
        [challenge.sender useCredential:[NSURLCredential credentialForTrust:challenge.protectionSpace.serverTrust] forAuthenticationChallenge:challenge];
    } else {
        [challenge.sender cancelAuthenticationChallenge:challenge];
    }

}
Run Code Online (Sandbox Code Playgroud)

目前SecTrustEvaluate总是返回结果等于kSecTrustResultRecoverableTrustFailure.我已使用iphone配置实用程序在手机上安装了带证书的配置文件,并将其标记为已验证,但未更改结果.

任何人都可以帮我获得任何一个kSecTrustResultProceedkSecTrustResultConfirm自签名证书的信任结果吗?

Dav*_*ant 4

您需要确保您的证书具有某些扩展名。我配置了具有以下扩展名的证书,它对我有用(OpenSSL 格式):

basicConstraints=critical,CA:FALSE
extendedKeyUsage=serverAuth
subjectAltName=IP:192.168.x.y
Run Code Online (Sandbox Code Playgroud)