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上启动。

相关推荐
行走的搬运工几秒前
Spring Security_05
java·spring·mybatis
我登哥MVP3 分钟前
【Spring6笔记】 - 11 - JDBCTemplate
java·数据库·spring boot·mysql·spring
用户585343788434 分钟前
Harness Engineering:从 Prompt、Context 到 Agent 系统工程
人工智能·后端
ServBay5 分钟前
这9个高性能的Rust库不容错过
后端·rust
snakeshe101011 分钟前
从零理解容器化:Docker 核心原理与 Kubernetes 初探
后端
也许明天y14 分钟前
Spring AI 核心原理解析:基于 1.1.4 版本拆解底层架构
java·后端·spring
舒一笑18 分钟前
一文讲透 Temporal:为什么大厂都在用它做 AI 与分布式系统的“流程大脑”?
后端·程序员·llm
小红的布丁24 分钟前
BIO、NIO、AIO 与 IO 多路复用:select、poll、epoll 详解
java·数据库·nio
Elastic 中国社区官方博客25 分钟前
在 Elastic 中使用 OpenTelemetry 内容包可视化 OpenTelemetry 数据
大数据·开发语言·数据库·elasticsearch·搜索引擎
lifallen26 分钟前
Flink Checkpoint 流程、Barrier 流动与 RocksDB 排障
java·大数据·flink