将 x509Certificate 转换为 byte[] 并反转
Convert x509Certificate into byte[] and reverse
我想将 X509Certificate 转换为 byte[] 或 String,然后从 byte 获得 X509Certificate。
我用过这个代码
X509Certificate x509cert=Helper.saveCertificate(workgroupId, serialNumber);
//x509 to byte[]
ByteArrayOutputStream bos = new ByteArrayOutputStream();
ObjectOutput out = new ObjectOutputStream(bos);
out.writeObject(x509cert);
CertificateSerialization certificateSerialization=new CertificateSerialization();
certificateSerialization.setCertificateByte(bos.toByteArray());
bos.close();
return handleResult(certificateSerialization);
并通过此方法恢复:
byte[] x509cert=certificateSerialization.getCertificateByte();
//from byte to x509
ByteArrayInputStream bis = new ByteArrayInputStream(x509cert);
ObjectInput in = new ObjectInputStream(bis);
X509Certificate cert = (X509Certificate) in.readObject();
bis.close();
response.setResult(cert);
但是当我分析返回的 x509 时,这与原始证书不同。你认为有错误吗?
提前致谢
使用 String 我已经解决了我的问题,特别是我使用了这段代码:
将我的 x509Certificate
转换为字符串
Base64 encoder = new Base64(64);
String cert_begin = "-----BEGIN CERTIFICATE-----\n";
String end_cert = "-----END CERTIFICATE-----";
byte[] derCert = x509cert.getEncoded();
String pemCertPre = new String(encoder.encode(derCert));
String pemCert = cert_begin + pemCertPre + end_cert;
return pemCert;
同时将此字符串转换为 x509:
Security.addProvider(new org.bouncycastle.jce.provider.BouncyCastleProvider());
String pem=//PEM STRING
X509Certificate cert = null;
StringReader reader = new StringReader(pem);
PEMReader pr = new PEMReader(reader);
cert = (X509Certificate)pr.readObject();
pr.close();
使用X509Certificate.getEncoded()
byte[] java.security.cert.Certificate.getEncoded() throws CertificateEncodingException
getEncoded() returns 此证书的编码形式。假定每种证书类型只有一种编码形式;例如,X.509 证书将被编码为 ASN.1 DER。
我想将 X509Certificate 转换为 byte[] 或 String,然后从 byte 获得 X509Certificate。 我用过这个代码
X509Certificate x509cert=Helper.saveCertificate(workgroupId, serialNumber);
//x509 to byte[]
ByteArrayOutputStream bos = new ByteArrayOutputStream();
ObjectOutput out = new ObjectOutputStream(bos);
out.writeObject(x509cert);
CertificateSerialization certificateSerialization=new CertificateSerialization();
certificateSerialization.setCertificateByte(bos.toByteArray());
bos.close();
return handleResult(certificateSerialization);
并通过此方法恢复:
byte[] x509cert=certificateSerialization.getCertificateByte();
//from byte to x509
ByteArrayInputStream bis = new ByteArrayInputStream(x509cert);
ObjectInput in = new ObjectInputStream(bis);
X509Certificate cert = (X509Certificate) in.readObject();
bis.close();
response.setResult(cert);
但是当我分析返回的 x509 时,这与原始证书不同。你认为有错误吗? 提前致谢
使用 String 我已经解决了我的问题,特别是我使用了这段代码: 将我的 x509Certificate
转换为字符串Base64 encoder = new Base64(64);
String cert_begin = "-----BEGIN CERTIFICATE-----\n";
String end_cert = "-----END CERTIFICATE-----";
byte[] derCert = x509cert.getEncoded();
String pemCertPre = new String(encoder.encode(derCert));
String pemCert = cert_begin + pemCertPre + end_cert;
return pemCert;
同时将此字符串转换为 x509:
Security.addProvider(new org.bouncycastle.jce.provider.BouncyCastleProvider());
String pem=//PEM STRING
X509Certificate cert = null;
StringReader reader = new StringReader(pem);
PEMReader pr = new PEMReader(reader);
cert = (X509Certificate)pr.readObject();
pr.close();
使用X509Certificate.getEncoded()
byte[] java.security.cert.Certificate.getEncoded() throws CertificateEncodingException
getEncoded() returns 此证书的编码形式。假定每种证书类型只有一种编码形式;例如,X.509 证书将被编码为 ASN.1 DER。