Hello I’m trying to use de SOAP web service connector(6.2.4) to consume a secure service (user and password required) I put all the needed configurations in the connector but I’m receiving this error:
sun.security.validator.ValidatorException: PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target
It seems to be the SSL certificate, so I include the server (where the service is running) certificate in the cacert of my jdk and jre, but still don’t work.
Is there another truststore specific for bonita?
Is there a way to tell bonita where to find the right keystore?
What should I do?
Hello, here I go with a quick guide based on my case, I´m not a Bonita guru, just a starter so maybe this approach could be enhanced:
In my case I have to consume a secure web service with a security policy that requires user, password and timestamp also the communication between client (Bonita) and server (service host) will be encrypted using SSL, so the client needs the servers certificate.
First you should import the server certificate on the client truststore(as I understand Bonita uses the one provided for the JVM, a file named cacerts located in JAVA_HOME \jre\lib\security).
Although the SOAP web service connector comes with some features to configure username, password and headers, I tried it only once and it didn´t worked for me(maybe because I really couldn’t find a lot info in how to use those features, perhaps someone with more knowledge about this matter could make a better explanation here, so we can use them in a better way). So, I didn´t use those features and worked directly on the message structure using the envelope field of the wizard.
To construct the message I use SOAPUI (tool that allows test services), using it I came with this message structure for my case:
<soapenv:Envelope xmlns:soapenv=“http://schemas.xmlsoap.org/soap/envelope/” xmlns:typ=“http://www.wso2.org/types”>
soapenv:Header
<wsse:Security xmlns:wsse=“http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd” xmlns:wsu=“http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd”>
<wsu:Timestamp wsu:Id=“TS-2”>
wsu:Created2014-04-07T15:23:34.750Z</wsu:Created>
wsu:Expires2020-04-07T15:40:14.750Z</wsu:Expires>
</wsu:Timestamp>
<wsse:UsernameToken wsu:Id=“UsernameToken-1”>
wsse:Username${username}</wsse:Username>
<wsse:Password Type=“http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-username-token-profile-1.0#PasswordText”>${pass}</wsse:Password>
wsu:Created2014-04-07T15:23:34.750Z </wsu:Created>
</wsse:UsernameToken>
</wsse:Security>
</soapenv:Header>
soapenv:Body
typ:greet
${greet}
</typ:greet>
</soapenv:Body>
</soapenv:Envelope>
As you can see, I added some headers containing username, password and timestamp.
Adding a groovy connector to specify the properties that rig told me before, could be useful to be sure that Bonita is using the right truststore.
System.setProperty(“javax.net.ssl.trustStore”, “path to your truststore”);
System.setProperty(“javax.net.ssl.trustStorePassword”, “password of your truststore”);
Hope this could help you
We need to import a certificate means we need to use :
keytool -importcert -file <certificate_location> -keystore <jre_location\lib\security\cacerts> -alias "<cert_name>"
It will ask for a password. Type the password as changeit
Type Password : changeit
finally it will ask need to add {yes/no} :
type yes.
Note: Don't give blank space in location path
https://stackoverflow.com/questions/684081/importing-ssl-certificate-into-eclipse
Hi,
could you complete your question by giving us the methods you used to configure the certificate in your JVM?
You may also test in a groovy script the output of:
System.out.println(System.getProperty(“javax.net.ssl.trustStore”));
System.out.println(System.getProperty(“javax.net.ssl.keyStore”));
Hello rig and thanks for your interest,
I trying to consume a service that is hosted in my own PC in a web server, So I followed this steps
- Browse the console of the web server
- Download the provided .crt
- Import the .crt in the cacerts file stored C:\Program Files\Java\jdk1.6.0_25\jre\lib\security using the import command of the keytool
- Say yes at the question of trust
When I ask for those properties you told me, I gat null as answer, nevertheless I removed the username and password from the configurations and included some XML headers in the envelope with username, password and timespan and it worked.
Thanks again
Hi,
I have exactly the same problem. I am invoking a secured web service. I have add the cert to the java secure truststore (cacert) and I succeed to discovering the ws but invoking it. I get the same PKIX error.
any help?
Hi mordor,
could you create an answer with your solution (with the full example of config and headers)? it seems that other people share your issue
Thx for your support.