Spring Boot – Enabling HTTPS

By default, Spring Boot application uses HTTP 8080 port when the application starts up.

Started Application on Tomcat port_8080

You need to follow the steps given below to configure the HTTPS and the port 443 in Spring Boot application −

  • Obtain the SSL certificate – Create a self-signed certificate or get one from a Certificate Authority
  • Enable HTTPS and 443 port

1. Self-Signed Certificate

To create a self-signed certificate, Java Run Time environment comes bundled with certificate management utility key tool. This utility tool is used to create a Self-Signed certificate. It is shown in the code given here −

keytool -genkey -alias tomcat -storetype PKCS12 -keyalg RSA -keysize 2048 -keystore keystore.p12 -validity 3650
Enter keystore password:
   Re-enter new password:
   What is your first and last name?
   [Unknown]:
   What is the name of your organizational unit?
   [Unknown]:
   What is the name of your organization?
   [Unknown]:
   What is the name of your City or Locality?
   [Unknown]:
   What is the name of your State or Province?
   [Unknown]:
   What is the two-letter country code for this unit?
   [Unknown]:
   Is CN = Unknown, OU=Unknown, O = Unknown, L = Unknown, ST = Unknown, C = Unknown correct?
   [no]: yes

This code will generate a PKCS12 keystore file named as keystore.p12 and the certificate alias name is tomcat.

2. Configure HTTPS

We need to provide the server port as 443, key-store file path, key-store-password, key-store-type and key alias name into the application.properties file. Observe the code given here −

server.port: 443
server.ssl.key-store: keystore.p12
server.ssl.key-store-password: springboot
server.ssl.keyStoreType: PKCS12
server.ssl.keyAlias: tomcat

You can use the following code if you are using YAML properties use below application.yml −

server:
   port: 443
   ssl:
      key-store: keystore.p12
      key-store-password: springboot
      keyStoreType: PKCS12
      keyAlias: tomcat

You can create an executable JAR file, and run the spring boot application by using the following Maven or Gradle commands.

For Maven, you can use the following command −

mvn clean install

After “BUILD SUCCESS”, you can find the JAR file under the target directory.

For Gradle, you can use the command

gradle clean build

After “BUILD SUCCESSFUL”, you can find the JAR file under the build/libs directory.

Now, run the JAR file by using the following command −

java –jar <JARFILE>

Now, the application has started on the Tomcat port 443 with https as shown −

Started Application on Tomcat Port 443

Related posts:

Java Program to Check whether Graph is a Bipartite using BFS
Easy Ways to Write a Java InputStream to an OutputStream
Java Program to Find the Edge Connectivity of a Graph
Java Program to Apply Above-Below-on Test to Find the Position of a Point with respect to a Line
Java Program to Implement Heap Sort Using Library Functions
Spring Boot Security Auto-Configuration
Iterable to Stream in Java
Spring Security Logout
How to Replace Many if Statements in Java
Introduction to PCollections
Sử dụng CountDownLatch trong Java
Java Program to Implement Bellman-Ford Algorithm
Hướng dẫn Java Design Pattern – Null Object
ETL with Spring Cloud Data Flow
Java Program to Implement Vector API
Giới thiệu HATEOAS
Java Program to Implement Circular Singly Linked List
Lập trình đa luồng với CompletableFuture trong Java 8
Introduction to Project Reactor Bus
Setting the Java Version in Maven
Java Program to Implement Trie
The HttpMediaTypeNotAcceptableException in Spring MVC
Java Program to Implement Sorted List
Java Program to Find the Shortest Path from Source Vertex to All Other Vertices in Linear Time
Tránh lỗi ConcurrentModificationException trong Java như thế nào?
How to Read HTTP Headers in Spring REST Controllers
Spring Security Basic Authentication
4 tính chất của lập trình hướng đối tượng trong Java
Java InputStream to String
OAuth2 for a Spring REST API – Handle the Refresh Token in AngularJS
Ép kiểu trong Java (Type casting)
Implementing a Runnable vs Extending a Thread