Springboot设置Https

1、修改配置文件application.yml,并将*.jks放到resource目录下。

bash 复制代码
server:
  port: 8080
  ssl:
    key-store: classpath:*.jks
    key-store-password: *
    key-store-type: JKS
    enabled: true
    key-alias: boe.com.cn

2、添加http转https的配置

java 复制代码
@Configuration
public class TomcatConfig {
    @Bean
    public TomcatServletWebServerFactory servletContainer() {
        TomcatServletWebServerFactory tomcat = new TomcatServletWebServerFactory() {
            @Override
            protected void postProcessContext(Context context) {
                SecurityConstraint constraint = new SecurityConstraint();
                constraint.setUserConstraint("CONFIDENTIAL");
                SecurityCollection collection = new SecurityCollection();
                collection.addPattern("/*");
                constraint.addCollection(collection);
                context.addConstraint(constraint);
            }
        };
        tomcat.addAdditionalTomcatConnectors(httpConnector());
        return tomcat;
    }

    @Bean
    public Connector httpConnector() {
        Connector connector = new Connector("org.apache.coyote.http11.Http11NioProtocol");
        connector.setScheme("http");
        //Connector监听的http的端口号
        connector.setPort(8082);
        connector.setSecure(false);
        //监听到http的端口号后转向到的https的端口号
        connector.setRedirectPort(8080);
        return connector;
    }
}

3、修改pom.xml文件

一般到上一步,本地运行没有什么问题,但是打包会有问题。

xml 复制代码
<plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-resources-plugin</artifactId>
    <version>3.1.0</version>
    <configuration>
        <nonFilteredFileExtensions>
            <!-- 过滤后缀为jks的证书文件 -->
            <nonFilteredFileExtension>jks</nonFilteredFileExtension>
        </nonFilteredFileExtensions>
    </configuration>
</plugin>

此时打包应该没有问题,但是部署时可能会出现端口问题,如果出现就添加一下代码

xml 复制代码
<resource>
  <directory>src/main/resources</directory>
  <filtering>true</filtering>
  <excludes>
      <!-- 替换成自己的证书文件 -->
      <exclude>*.jks</exclude>
  </excludes>
</resource>
<resource>
  <directory>src/main/resources</directory>
  <filtering>false</filtering>
  <includes>
      <!-- 替换成自己的证书文件 -->
      <include>*.jks</include>
  </includes>
</resource>

另外,如果还有问题,就很可能是端口问题,8090这个端口配置一直不成功,换成8080就好了。

相关推荐
bcbnb2 分钟前
Ipa Guard 集成到 CICD 流程,让 iOS 加固进入自动化时代的完整工程方案
后端
该用户已不存在11 分钟前
2025 年 8 款最佳远程协作工具
前端·后端·远程工作
云渠道商yunshuguoji26 分钟前
阿里云渠道商:阿里云服务器出问题如何处理?
后端
dyw081 小时前
如何通过xshell实现建立反向隧道,通过云服务器的访问本地服务
后端
changflow2 小时前
告别“黑盒”等待:如何在 LangGraph 中优雅地实现前端友好的 Human-in-the-Loop?
后端
惜棠2 小时前
visual code + rust入门指南
开发语言·后端·rust
n***i952 小时前
Rust在嵌入式系统中的内存管理
开发语言·后端·rust
踏浪无痕2 小时前
PageHelper 防坑指南:从兜底方案到根治方案
spring boot·后端
ziwu2 小时前
昆虫识别系统【最新版】Python+TensorFlow+Vue3+Django+人工智能+深度学习+卷积神经网络算法
后端·图像识别
三翼鸟数字化技术团队2 小时前
基于redis的多资源分布式公平锁的设计与实践
redis·后端