0

我正在开发一个文件共享应用程序。它适用于两个 iOS 设备之间的 TCP 连接,我需要它们之间的安全连接。我正在使用 GCDAsyncSocket 库进行连接。我之前使用这个库来连接其他接受 SSL 连接的应用程序,所以我对客户端没有任何问题。这是问题;如何托管仅接受具有有效 SSL 证书的 SSL 连接的套接字?谢谢。

4

1 回答 1

0

我终于解决了我的问题。在didAcceptNewSocket委托方法中,我使用这些设置加载我的证书。

NSDictionary *settings = @{(NSString *)kCFStreamPropertyShouldCloseNativeSocket:    [NSNumber numberWithBool:YES],
                           (NSString *)kCFStreamSSLValidatesCertificateChain:       [NSNumber numberWithBool:YES],
                           (NSString *)kCFStreamSSLAllowsExpiredCertificates:       [NSNumber numberWithBool:NO],
                           (NSString *)kCFStreamSSLAllowsExpiredRoots:              [NSNumber numberWithBool:NO],
                           (NSString *)kCFStreamSSLAllowsAnyRoot:                   [NSNumber numberWithBool:YES],
                           (NSString *)kCFStreamSSLCertificates:                    certificates,
                           (NSString *)kCFStreamSSLIsServer:                        [NSNumber numberWithBool:YES],
                           (NSString *)kCFStreamSSLLevel:                           (NSString *)kCFStreamSocketSecurityLevelTLSv1}; 
于 2014-02-21T09:31:37.430 回答