ios端自定义验证ssl证书

在iOS端,我们可以通过自定义验证SSL证书来增强我们应用的安全性。SSL证书是一种公钥加密技术,用于保护网站的安全性。在HTTPS协议中,SSL证书用于验证服务器身份,确保通信双方的安全性。在默认情况下,iOS会使用系统根证书进行验证,但是有些情况下,我们需要自定义验证证书。

自定义验证SSL证书的原理:

当我们向一个服务器发送HTTPS请求时,服务器会返回一个SSL证书。客户端会使用该证书来验证服务器的身份。验证过程如下:

1. 客户端会检查证书是否过期,如果过期,会拒绝连接。

2. 客户端会检查证书是否由可信的证书颁发机构颁发。如果不是,则会拒绝连接。

3. 客户端会检查证书中的域名是否与请求的域名匹配。如果不匹配,则会拒绝连接。

自定义验证SSL证书的过程:

1. 获取证书

我们可以通过以下代码获取到服务器返回的证书:

```

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

{

if ([challenge.protectionSpace.authenticationMethod isEqualToString:NSURLAuthenticationMethodServerTrust]) {

SecTrustRef trust = challenge.protectionSpace.serverTrust;

SecCertificateRef cert = SecTrustGetCertificateAtIndex(trust, 0);

NSData *certData = CFBridgingRelease(CFDataCreateCopy(NULL, SecCertificateCopyData(cert)));

// 处理证书

}

}

```

2. 信任证书

我们可以通过以下代码来信任证书:

```

SecTrustSetAnchorCertificates(trust, (__bridge CFArrayRef)@[certData]);

SecTrustSetAnchorCertificatesOnly(trust, YES);

SecTrustResultType result;

SecTrustEvaluate(trust, &result);

if (result == kSecTrustResultUnspecified || result == kSecTrustResultProceed) {

// 证书验证通过

[challenge.sender useCredential:[NSURLCredential credentialForTrust:challenge.protectionSpace.serverTrust] forAuthenticationChallenge:challenge];

} else {

// 证书验证失败

[challenge.sender cancelAuthenticationChallenge:challenge];

}

```

在这段代码中,我们将获取到的证书添加到了信任锚点列表中,并设置了只信任该列表中的证书。然后使用`SecTrustEvaluate()`方法来验证证书。如果验证通过,则使用`NSURLCredential`来创建一个凭证,并使用`useCredential:forAuthenticationChallenge:`方法来告诉系统使用该凭证来通过验证。如果验证失败,则使用`cancelAuthenticationChallenge:`方法来取消验证。

3. 处理证书

在获取到证书后,我们还需要处理证书。我们可以通过以下代码获取证书的信息:

```

SecCertificateRef cert = SecCertificateCreateWithData(NULL, (__bridge CFDataRef)certData);

CFStringRef cnRef = NULL;

SecCertificateCopyCommonName(cert, &cnRef);

NSString *commonName = (__bridge_transfer NSString *)cnRef;

```

在这段代码中,我们使用`SecCertificateCreateWithData()`方法来创建一个证书对象,并使用`SecCertificateCopyCommonName()`方法来获取证书的公共名称。

这样,我们就可以通过自定义验证SSL证书来增强我们应用的安全性。