Spring Boot-HTTPS 활성화

기본적으로 Spring Boot 애플리케이션은 애플리케이션이 시작될 때 HTTP 8080 포트를 사용합니다.

Spring Boot 애플리케이션에서 HTTPS 및 포트 443을 구성하려면 아래 단계를 따라야합니다.

  • SSL 인증서 받기 – 자체 서명 된 인증서를 만들거나 인증 기관에서 가져옵니다.

  • HTTPS 및 443 포트 활성화

자체 서명 된 인증서

자체 서명 된 인증서를 생성하기 위해 Java 런타임 환경은 인증서 관리 유틸리티 키 도구와 함께 번들로 제공됩니다. 이 유틸리티 도구는 자체 서명 된 인증서를 만드는 데 사용됩니다. 여기에 주어진 코드에 나와 있습니다.

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

이 코드는 keystore.p12라는 이름의 PKCS12 키 저장소 파일을 생성하고 인증서 별명은 tomcat입니다.

HTTPS 구성

서버 포트를 443, 키 저장소 파일 경로, 키 저장소 암호, 키 저장소 유형 및 키 별칭 이름으로 application.properties 파일에 제공해야합니다. 여기에 주어진 코드를 관찰하십시오-

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

YAML 속성을 사용하는 경우 다음 코드를 사용할 수 있습니다 application.yml-

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

다음 Maven 또는 Gradle 명령을 사용하여 실행 가능한 JAR 파일을 만들고 스프링 부트 애플리케이션을 실행할 수 있습니다.

Maven의 경우 다음 명령을 사용할 수 있습니다.

mvn clean install

“BUILD SUCCESS”후 대상 디렉토리에서 JAR 파일을 찾을 수 있습니다.

Gradle의 경우 다음 명령을 사용할 수 있습니다.

gradle clean build

“BUILD SUCCESSFUL”후에 build / libs 디렉토리에서 JAR 파일을 찾을 수 있습니다.

이제 다음 명령을 사용하여 JAR 파일을 실행하십시오.

java –jar <JARFILE>

이제 애플리케이션은 다음과 같이 https를 사용하여 Tomcat 포트 443에서 시작되었습니다.