by jNayden | Jul 11, 2019 | Aggregated, java.javaee
Linux Download multiple Java versions and put them into /opt/ If you already have some JDK from ubuntu repo or etc not a big deal, just fix the paths bellow Register them as alternatives sudo update-alternatives –install /usr/bin/java java /opt/java-8-oracle/bin/java 1081sudo update-alternatives –install /usr/bin/java java /opt/sap-machine-jdk-11.0.3/bin/java 1080 Edit your ~/.bashrc file alias java11=’sudo update-alternatives –set java /opt/sapmachine-jdk-11.0.3/bin/java;export JAVA_HOME=/opt/sapmachine-jdk-11.0.3/’alias java8=’sudo update-alternatives –set java /opt/java-8-oracle/bin/java;export JAVA_HOME=/usr/lib/java-8-oracle/’ SAVE and start a new bash terminal execute java8 to use java8java11 to use java11 the latest version you have set stays as system wide, but the JAVA_HOME is not 🙁 you can put java8 or java11 as a last line in the bashrc but since it is sudo it will always require password when start and is not great ;( Mac Install homebrew, since it rox ! Install Oracle Java 8 or OpenJDK 8. I recommend adoptopenjdk brew tap adoptopenjdk/openjdkbrew search adoptopenjdkbrew cask install adoptopenjdk8brew cask install adoptopenjdk11 On mac since it RULZ you have a java_home executable (that changes and fixes both your path and your JAVA_HOME) , so the .bashrc changes are easy ! Edit your ~/.bashrc file export JAVA_8_HOME=$(/usr/libexec/java_home -v1.8)export JAVA_11_HOME=$(/usr/libexec/java_home -v11)alias java8=’export JAVA_HOME=$JAVA_8_HOME’alias java11=’export JAVA_HOME=$JAVA_11_HOME’java8 Note: the latest execution of java8 is to make it system wide by default SAVE and start a new bash terminal execute java8 to use java8 java11 to use java11 Windows Use a normal OS or suffer...
by jNayden | Apr 11, 2019 | Aggregated, javaee, spring
As a follow up of the http://gochev.blogspot.com/2019/04/convert-pfx-certificate-to-jks-p12-crt.html we now have a keystore and a truststore (if anyone needs) and we will use this keystore to send client side authentication using Spring’s RestTemplate .First copy your keystore.jks and truststore.jks in your classpath, no one wants absolute paths right ?:)The magic happens in the creation of SSLContext. Keep in mind the Spring Boot have a nice RestTemplateBuilder but I will not gonna use it, because someone of you might have an older version or like me, might just use a plain old amazing Spring.If you just want to use the keystore:final String allPassword = “123456”;SSLContext sslContext = SSLContextBuilder .create() .loadKeyMaterial(ResourceUtils.getFile(“classpath:keystore.jks”), allPassword.toCharArray(), allPassword.toCharArray()) .build(); if you just want to use the truststore final String allPassword = “123456”;SSLContext sslContext = SSLContextBuilder .create() .loadTrustMaterial(ResourceUtils.getFile(“classpath:truststore.jks”), allPassword.toCharArray()) .build(); I guess you know how to use both ;), if you want to IGNORE the truststore certificate checking and trust ALL certificates (might be handy for testing purposes and localhost) final String allPassword = “123456”;TrustStrategy acceptingTrustStrategy = (X509Certificate[] chain, String authType) -> true;SSLContext sslContext = SSLContextBuilder .create() .loadTrustMaterial(ResourceUtils.getFile(“classpath:truststore.jks”), allPassword.toCharArray()) .loadTrustMaterial(null, acceptingTrustStrategy) //accept all .build();...
by jNayden | Apr 11, 2019 | Aggregated
I recently had to use a PFX certificate for client authentication (maybe another post will be coming) and for that reason I had to convert it to a Java keystore (JKS). We will create BOTH a truststore and a keystore, because based on your needs you might need one or the other. The difference between truststore and keystore if you are not aware is(quote from the JSSE ref guide: TrustManager: Determines whether the remote authentication credentials (and thus the connection) should be trusted. KeyManager: Determines which authentication credentials to send to the remote host. Ok that’s enough what you will need is openssl and Java 7+ 😉 ! First let’s generate a key from the pfx file, this key is later used for p12 keystore. openssl pkcs12 -in example.pfx -nocerts -out example.key Enter Import Password: MAC verified OK Enter PEM pass phrase: Verifying – Enter PEM pass phrase: As shown here you will be asked for the password of the pfx file, later you will be asked to enter a PEM passphase lets for example use 123456 for everything here. The second commands is almost the same but it is about nokey and a crt this time openssl pkcs12 -in example.pfx -clcerts -nokeys -out example.crt Enter Import Password: MAC verified OK Now we have a key and and a crt file Next step is to create a truststore. keytool -import -file example.crt -alias exampleCA -keystore truststore.jks Enter keystore password: Re-enter new password: Owner: CN=….. ……. Trust this certificate? [no]: yes Certificate was added to keystore As you can see here you just import this crt file into a jks truststore and set some password. For the question...
by jNayden | Feb 26, 2019 | Aggregated
Bad news everyone,as you already have noticed I do not have time to write blogs 🙁 However I would recommend you to check and keep an eye on the youtube channel of the Bulgarian Java User Group (http://jug.bg) which is https://www.youtube.com/user/BulgarianJUG/ You can enjoy all the jprime conference video recordings at https://www.youtube.com/user/BulgarianJUG/playlists but also checkout the videos tab since we have a lot of non jprime videos uploaded as well and maybe at some point you can even see me...
by jNayden | Jan 5, 2019 | Aggregated, other
Good news everyone, the videos of jPrime 2018 are freely available at https://www.youtube.com/watch?v=xs3heuY21Z0&list=PLcqA4DRMgIYvGPZfrK0EcMxEQCrtSl9A3 Also in Youtube Bulgarian Java User Group channel you may find a lot of helpful Java related videos from jPrime 2017, 2016, 2015 or other Bulgarian Java User Group talks and activities : https://www.youtube.com/user/BulgarianJUG/ Hope to see everyone of you at jPrime 2019 !Or some of the Bulgarian Java User Group (jug.bg) or java beer events...
Recent Comments