Android では、このコードで作成されたクライアント証明書との相互認証で TLS 接続を使用します。
private static X509Certificate generateX509V1Certificate(KeyPair pair, SecureRandom sr)
{
String dn="CN="+sUuid.toString();
final Calendar calendar = Calendar.getInstance();
calendar.add(Calendar.HOUR, -1);
final Date startDate = new Date(calendar.getTimeInMillis());
calendar.add(Calendar.YEAR, 1);
final Date expiryDate = new Date(calendar.getTimeInMillis());
final BigInteger serialNumber =
BigInteger.valueOf(Math.abs(System.currentTimeMillis()));
X509V1CertificateGenerator certGen = new X509V1CertificateGenerator();
X500Principal dnName = new X500Principal(dn);
certGen.setSerialNumber(serialNumber);
certGen.setIssuerDN(dnName);
certGen.setNotBefore(startDate);
certGen.setNotAfter(expiryDate);
certGen.setSubjectDN(dnName); // note: same as issuer
certGen.setPublicKey(pair.getPublic());
certGen.setSignatureAlgorithm("SHA256WithRSAEncryption");
if (VERSION.SDK_INT<VERSION_CODES.GINGERBREAD)
return certGen.generateX509Certificate(pair.getPrivate(), "BC");
else
return certGen.generate(pair.getPrivate(), sr);
}
キーペアのアルゴリズムは「RSA」です。暗号アルゴリズムは「RSA/ECB/PKCS1Padding」です。
Jelly Bean バージョンの前は問題なく動作しています。
Jelly bean で、呼び出すとエラーが発生する
socket.getSession().getPeerCertificates()
プロセスはログで強制終了されました:
E/NativeCrypto(1133): error:140C10F7:SSL routines:SSL_SET_PKEY:unknown certificate type
A/libc(1133): Fatal signal 11 (SIGSEGV) at 0x00000000 (code=1), thread 1233 (AsyncTask #1)
このバグを解決する方法がわかりません。
手伝って頂けますか ?