Pracuję nad projektem Android. Mam ciąg certyfikatu PEM:Zainstalować programowo certyfikat X509 w moim przypadku
-----BEGIN CERTIFICATE-----
MIIEczCCA1ugAwIBAgIBADANBgkqhkiG9w0BAQQFAD..AkGA1UEBhMCR0Ix
EzARBgNVBAgTClNvbWUtU3RhdGUxFDASBgNVBAoTC0..0EgTHRkMTcwNQYD
VQQLEy5DbGFzcyAxIFB1YmxpYyBQcmltYXJ5IENlcn..XRpb24gQXV0aG9y
...MANY LINES...
It8una2gY4l2O//on88r5IWJlm1L0oA8e4fR2yrBHX..adsGeFKkyNrwGi/
7vQMfXdGsRrXNGRGnX+vWDZ3/zWI0joDtCkNnqEpVn..HoX
-----END CERTIFICATE-----
(I przypisany powyżej łańcucha certyfikatów do zmiennej o nazwie CERT_STR
)
przekonwertować powyżej PEM ciąg do X509Certificate przez:
byte[] certBytes = CERT_STR.getBytes();
CertificateFactory certificateFactory = CertificateFactory.getInstance("X.509");
InputStream certIs = new ByteArrayInputStream(certBytes);
// now I get the X509 certificate from the PEM string
X509Certificate certificate = (X509Certificate) certificateFactory.generateCertificate(certIs);
Wtedy staram aby zainstalować programistycznie programowo:
Intent intent = KeyChain.createInstallIntent();
// because my PEM only contains a certificate, no private key, so I use EXTRA_CERTIFICATE
intent.putExtra(KeyChain.EXTRA_CERTIFICATE, certificate.getEncoded());
intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
context.startActivity(intent);
Kiedy Uruchamiam moją aplikację, widzę okno systemowe z napisem "Wyodrębnianie ...", Wiem, że system wyodrębnia mój certyfikat, ale to okno pokazuje tam cały czas mówiąc "Wydobywanie ...".
Dlaczego? Gdzie się mylę w moim kodzie, aby zainstalować certyfikat?
Kod, który posiadasz, wymaga certyfikatu binarnego, a nie kodowanego w standardzie base64. – Robert
@Robert, nie bardzo rozumiem twoje słowa, która część mojego kodu używa kodowania base64? –
Część między BEGINEM a END CERTIFICATE jest certyfikatem zakodowanym w base64. Certyfikat x.509 CertificateFactory wymaga certyfikatu binarnego AFAIR. – Robert