Avatar

Please consider registering
guest

sp_LogInOut Log In sp_Registration Register

Register | Lost password?
Advanced Search

— Forum Scope —




— Match —





— Forum Options —





Minimum search word length is 3 characters - maximum search word length is 84 characters

sp_Feed Topic RSS sp_TopicIcon
Issue with secure connection and certificates
January 27, 2022
11:22, EET
Avatar
martin_prosys
Member
Members
Forum Posts: 14
Member Since:
January 27, 2022
sp_UserOfflineSmall Offline

Hi everyone,

I was following the examples in order to establish a secure connection from our application to an OPC-UA server. My code goes like this:

uaClient = clientFactory.createClient(serverUrl);
ApplicationDescription appDescription = new ApplicationDescription();
appDescription.setApplicationName(new LocalizedText(“AppName”));
appDescription.setApplicationUri(“urn:test.com:OPCUA:AppName”);
appDescription.setProductUri(“urn:test.com:OPCUA:AppName”);
appDescription.setApplicationType(ApplicationType.Client);

File privatePath = new File(“./keys”, “private”);
// Create self-signed certificates
KeyPair issuerCertificate = null;
int[] keySizes = null;

ApplicationIdentity identity = ApplicationIdentity.loadOrCreateCertificate(
appDescription,
“CompanyName”,
“password”,
privatePath,
issuerCertificate,
keySizes,
true);

uaClient.setApplicationIdentity(identity);
uaClient.setSecurityMode(SecurityMode.BASIC128RSA15_SIGN_ENCRYPT);
uaClient.setValidateDiscoveredEndpoints(!debugMode);
uaClient.setInitTypeDictionaryOnConnect(false);

This works perfectly fine if I have set the OPC server to accept untrusted certificates. However, if I set it to accept only trusted certificates and add the certificate generated by the above code to its “trusted” folder (after converting from .der to .pem as this is required by the OPC server) the communication fails with the following error:
Failed to create secure channel to server
Bad_SecurityChecksFailed (0x80130000) “An error occurred verifying security
However, I noticed that a file with identical contents to my .pem placed in the “trusted” folder gets created in the “untrusted” folder of the server, but this time named “23AD68F5.0”. I tried restarting the OPC server and this time renamed my .pem to “23AD68F5.0” and placed it in the “trusted” folder and the communication works fine.

I have no idea where this 23AD68F5.0 comes from – can someone here explain? Why doesn’t it work if I set an arbitrary name for the certificate?

January 27, 2022
11:55, EET
Avatar
Matti Siponen
Moderator
Members

Moderators
Forum Posts: 349
Member Since:
February 11, 2020
sp_UserOfflineSmall Offline

Hello,

Which version of the Prosys OPC UA SDK for Java are you using? Some older versions might require restarting the Server to notice manually added and removed certificates in trusted and untrusted folders.

If you’re using 4.6.2 or a more recent version, could you provide the exact steps on replicating this issue? With newer versions of the SDK, you should be able move a certificate from untrusted folder to trusted folder and have the Server consider it trusted immediately without having to restart the Server.

When saving a certificate received via OPC UA to file system, the SDK uses the thumbprint of the certificate to decide the file name. However, the filenames of certificate files shouldn’t matter as the SDK checks all certificate files in trusted and untrusted folders whenever it checks if a certificate is trusted.

January 27, 2022
12:47, EET
Avatar
martin_prosys
Member
Members
Forum Posts: 14
Member Since:
January 27, 2022
sp_UserOfflineSmall Offline

Hi Matti and thank you very much for your reply. We are using version 4.4.0-1240 of the prosys-opc-ua-sdk-client for Java – I will try to update to the newest one.
However, we are adding the certificate to the trusted folder of the OPC server prior to its startup (we copy it there when the docker container for the OPC server is starting up). Our client app attempts to connect to the OPC server long after that. We are using the Tani OPC server if that matters.

January 27, 2022
13:07, EET
Avatar
Matti Siponen
Moderator
Members

Moderators
Forum Posts: 349
Member Since:
February 11, 2020
sp_UserOfflineSmall Offline

Hello,

I made a mistake and assumed that the Server you were attempting to connect to had been developed with Prosys OPC UA SDK for Java. While updating your Client to use a newer version of the SDK won’t affect this issue, the newest version of the SDK includes a security fix and everyone is recommended to update to it. See https://downloads.prosysopc.com/opcua/Prosys_OPC_UA_SDK_for_Java_4_Release_Notes.html#version-4-7-0 for more information.

Regarding the issue with certificates, please, contact the manufacturers of the Server for assistance.

January 27, 2022
13:50, EET
Avatar
martin_prosys
Member
Members
Forum Posts: 14
Member Since:
January 27, 2022
sp_UserOfflineSmall Offline

Thanks a lot, I had asked them as well.
With regards to the name of the certificate file – I tried extracting the thumbprint you mentioned via openssl by following the advice here: https://community.rsa.com/t5/securid-knowledge-base/how-to-view-a-certificate-fingerprint-as-sha-256-sha-1-or-md5/ta-p/4230 and here: https://support.comodo.com/index.php?/comodo/Knowledgebase/Article/View/706/17/ but the output never contains 23AD68F5.0. Can you suggest an openssl command that would print the information you mentioned – i.e. one that should match the name of the file as per created by the Prosys OPC UA SDK had we been using it?

January 27, 2022
14:31, EET
Avatar
Matti Siponen
Moderator
Members

Moderators
Forum Posts: 349
Member Since:
February 11, 2020
sp_UserOfflineSmall Offline

Hello,

When I said that the filename is the certificate thumbprint I was assuming your Server had been made with the Prosys OPC UA SDK for Java. Since it isn’t, there is no way for us to know how that Tani OPC Server names certificate files. You will have to contact them for help.

January 27, 2022
14:58, EET
Avatar
martin_prosys
Member
Members
Forum Posts: 14
Member Since:
January 27, 2022
sp_UserOfflineSmall Offline

Yeah, sorry, I realise that. It is just that I haven’t got a response from them yet and I was wondering if I can try to reverse engineer the name somehow in the meantime.
I was asking about the openssl command in case they are using the same logic for the file name (I can quickly check that given the openssl command)

January 27, 2022
15:13, EET
Avatar
Matti Siponen
Moderator
Members

Moderators
Forum Posts: 349
Member Since:
February 11, 2020
sp_UserOfflineSmall Offline

Hello,

You should be able to open the DER file of the certificate with a certificate viewer to view its information including the thumbprint.

Help with OpenSSL is outside the scope of support on this forum.

January 27, 2022
15:26, EET
Avatar
martin_prosys
Member
Members
Forum Posts: 14
Member Since:
January 27, 2022
sp_UserOfflineSmall Offline

Much appreciated 🙂

Forum Timezone: Europe/Helsinki

Most Users Ever Online: 1919

Currently Online:
42 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: 747

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, Georgecotag

Moderators: Jouni Aro: 1026, Pyry: 1, Petri: 0, Bjarne Boström: 1032, Jimmy Ni: 26, Matti Siponen: 349, Lusetti: 0

Administrators: admin: 1