12:24, EET
March 16, 2017
Hi,
I have a question about the keystore format when i load the application identity from a keystore.
I’ve created a keystore using the java keytool.exe with storetype PKCS12
When loading the Application idenity my expectation was that I get an error message if I pass in a wrong keyStoreFormat to the constructer – but somehow, the ApplicationIdenty was created corretly.
ApplicationIdentity applicationIdentity = new ApplicationIdentity(new File("./theKeyStore.pfx"), "alias", "keyPass", "keyStorePass", keyStoreFormat);
So is there any fallback or something like this when I pass in the wrong keyStoreFormat into the constructer?
What happens with the key store format? In the Javadoc of the SDK, there is not really any description about the keystore format.
Thanks!
15:23, EET
December 21, 2011
A very good question.
Internally, this leads to the following code:
But reading the documentation of KeyStore says if you use “JKS”,
“The system will return the most preferred implementation of the specified keystore type available in the environment.”
And since PKCS12 is nowadays the preferred KeyStore format, I guess it works like you experience. So, in other words, “JKS” and “PKCS12” are equal in practice.
15:55, EET
March 16, 2017
Hi,
thanks for clarification – so basically it would be possible to use any of the storetypes listed in the java documentation (e.g. https://docs.oracle.com/en/java/javase/11/docs/specs/security/standard-names.html#keystore-types)
17:17, EET
April 3, 2012
Hi,
As far as I’m aware, we do not use this version of the constructor ourselves (nor any tests of today call it). That constructor predates me working with the SDK and it is possible that it had more use in the past (or that some use was intended but not finalized in a release, this is ~10 years old stuff).
That being said, we could maybe use a bit more support for more standard “security APIs” in the SDK etc. so if something doesn’t work let us know and hopefully we can fix things if needed. I know that historically there were some problems in older java versions and doing things via BouncyCastle directly was a working solution. Also I believe in Java 6 time the keytool did lack some parameters that would be needed for OPC UA, but my understanding of the keytool is a bit limited (I have used it, but not much).
Anyway all other ApplicationIdentity constructors take in paths to the certificate (typically as .der file)+private keys (typically as .pem file) or them directly as objects. I would personally probably say they would be the preferred way as of today, i.e. the way SDK is normally expected to be used (and we use it like this) does not involve any KeyStores etc. and keytool usage. The CertificateStore interface is used to hold the “truststore” so to say and the normally used (included) implementation PkiDirectoryCertificateStore stores them in .der files on disk. That being said, we do not have “a CertificateStore” concept for the application’s own certs.
The constructor you are using basically just delegates to the super class’ constructor:
“
/**
* Creates a new SecureIdentity object from a pfx-keystore file.
*
* @param storeLocation location of the pfx-file
* @param alias string alias of the key pair, if null or not found in specified pfx-file, last
* entry is used
* @param privateKeyPassword password of the private key
* @param keyStorePassword password of the keystore
* @param keyStoreType type of the key store, “JKS” and “PKCS12” supported
* @throws KeyStoreException if the keystore has not been initialized (loaded)
* @throws NoSuchProviderException if the specified provider (Bouncy Castle) is not registered in
* the security provider list
* @throws NoSuchAlgorithmException if the algorithm used to check the integrity of the keystore
* cannot be found
* @throws CertificateException if any of the certificates in the keystore could not be loaded
* @throws IOException
* @throws UnrecoverableKeyException if a key in the keystore cannot be recovered
*/
public SecureIdentity(File storeLocation, String alias, String privateKeyPassword, String keyStorePassword,
String keyStoreType) throws IOException, SecureIdentityException
“
Thus, per that documentation (which is very old) “JKS” and “PKCS12” are the supported ones. That being said, as long as code-wise the return of KeyStore.getKey of the loaded keystore from the file given can be casted to java.security.interfaces.RSAPrivateKey it should maybe work (and KeyStore.getCertificate must be castable to java.security.cert.X509Certificate, but that I would assume to be more likely to happen always). Please let us know if something does not work.
17:37, EET
March 16, 2017
Hi Bjarne,
thanks for the answers. Currently I’m using often keystores created with the keytool. I do not use the Prosys API to create the pem, der files, cause I’m deploying the application certificate keystores directly to the OpcUa servers.
>>I know that historically there were some problems in older java versions
Yes, at least since Java 8 (propably also 7) it is possible to create keystores suitable for OpcUa with the keytool.
One thing you have to take care of is, that a keystore created with a newer Java version than the application is actually running with might result in a failure when opening the keystore.
Most Users Ever Online: 1919
Currently Online:
32 Guest(s)
Currently Browsing this Page:
1 Guest(s)
Top Posters:
Heikki Tahvanainen: 402
hbrackel: 144
rocket science: 88
pramanj: 86
Francesco Zambon: 83
Ibrahim: 78
Sabari: 62
kapsl: 57
gjevremovic: 49
Xavier: 43
Member Stats:
Guest Posters: 0
Members: 746
Moderators: 7
Admins: 1
Forum Stats:
Groups: 3
Forums: 15
Topics: 1529
Posts: 6471
Newest Members:
scvchad954, misty3446453365, KelsonzFu, Kelsonz, lienbelisario, erick34s63346, Kaitlyntvsl, lonaerskine7, KTP21ideft, GeorgecotagModerators: Jouni Aro: 1026, Pyry: 1, Petri: 0, Bjarne Boström: 1032, Jimmy Ni: 26, Matti Siponen: 349, Lusetti: 0
Administrators: admin: 1