1、将证书转成bks格式;转换方法自行解决
2、
public static final String ALGORITHM = "X509";
public static final String PASSWORD = "123456";
private static final String CLIENT_KEY_KEYSTORE = "BKS";// 密库,这里用的是BouncyCastle密库
private static TradeSocketThread tradeSocket;
SocketFactory socketFactory = initSSL(serverInfo);
if (socketFactory != null) {
tradeSocket = new TradeSocketThread(handler, serverInfo, context,
socketFactory);
tradeSocket.start();
}
private static SocketFactory initSSL(ServerInfo serverInfo) {
KeyManagerFactory kmf;
try {
kmf = KeyManagerFactory.getInstance(ALGORITHM);
KeyStore ks = KeyStore.getInstance(CLIENT_KEY_KEYSTORE);
ks.load(serverInfo.getSignaFile(), PASSWORD.toCharArray());
kmf.init(ks, PASSWORD.toCharArray());
TrustManagerFactory tmf = TrustManagerFactory
.getInstance(ALGORITHM);
tmf.init(ks);
SSLContext sslc = SSLContext.getInstance("TLS");
sslc.init(kmf.getKeyManagers(), tmf.getTrustManagers(), null);
SocketFactory socketFactory = sslc.getSocketFactory();
return socketFactory;
} catch (Exception e) {
e.printStackTrace();
return null;
}
}
mSocket = socketFactory.createSocket(serverInfo.getHost(), serverInfo.getPort());