16. Spring Boot启用HTTPS

16. Spring Boot启用HTTPS

默认情况下,Spring Boot应用程序在应用程序启动时使用HTTP的8080端口。

  • 获取SSL证书 - 创建自签名证书或从证书颁发机构获取证书
  • 启用HTTPS和443端口

自签证书

要创建自签名证书,Java运行时环境与证书管理实用程序密钥工具捆绑在一起。 此实用程序工具用于创建自签名证书。 它显示在这里给出的代码中 -

复制代码
path_to_keytool > keytool.exe -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

在application.properties文件中提供服务器端口:443,密钥存储文件路径,密钥存储密码,密钥存储类型和密钥别名。如下给出的代码 -

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

如果是在application.yml 下面使用YAML属性,则可以使用以下代码 -

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

可以创建可执行的JAR文件,并使用以下Maven或Gradle命令运行spring boot应用程序。

对于Maven,可以使用以下命令 -

复制代码
mvn clean install

在"BUILD SUCCESS"之后,在target 目录下找到JAR文件。

现在,使用以下命令运行JAR文件 -

java --jar <JARFILE>

现在,应用程序已在Tomcat端口443上启动。

相关推荐
凭君语未可4 分钟前
Java 中的接口是什么
java·开发语言
XiYang-DING5 分钟前
【Java】二叉树
java·开发语言·数据结构
databook7 分钟前
逃离SQL丛林:实用主义的数据救赎
后端·sql·数据分析
凌冰_15 分钟前
Servlet+Thymeleaf + Fetch 实现无刷新异步请求
java·servlet
下北沢美食家15 分钟前
JavaScript面试题2
开发语言·javascript·ecmascript
深蓝轨迹21 分钟前
面试常见的jdk---LTS版本新特性梳理
java·面试·jdk
数据知道36 分钟前
claw-code 源码分析:大型移植的测试哲学——如何用 unittest 门禁守住「诚实未完成」的口碑?
开发语言·python·ai·claude code·claw code
Stella Blog38 分钟前
狂神Java基础学习笔记Day01
java·笔记·学习
李白的天不白39 分钟前
java处理跨域请求
java
舒一笑43 分钟前
AI 系统落地难的,从来不只是模型:一次企业级部署实施复盘
运维·后端·程序员