springboot项目接口http转https(配置阿里云或者腾讯云的SSL证书)

本文详细指导如何为SpringBoot应用配置阿里云和腾讯云的.pfx和.jks证书,包括证书申请、application.properties中的配置及启动类代码调整。适合Tomcat用户快速部署HTTPS服务。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、申请阿里云/腾讯云证书

按照阿里云或者腾讯云去申请免费的一年证书即可,申请下来的目录结构如下:
Apache
IIS
Nginx
Tomcat
有目前主流服务器的证书文件,主要NginxTomcat用的多,咱们用的是Springboot所以就使用Tomcat下面的证书;

2、项目内配置证书

下面以application.properties为例(别问我为什么不用.yml
阿里云和腾讯云的区别就是证书文件的后缀不同,阿里云是.pfx,腾讯云是.jks,所以配置稍微微有点区别,都不算区别;

(1)阿里云配置 .pfx

#项目端口号和请求路径
server.port=10006
server.servlet.context-path=/xxx-wx-server
#配置证书
server.ssl.key-store=classpath:xxxAbcxxx.com.pfx
server.ssl.key-store-password=xxxxxxxxxxxxxxxx
server.ssl.key-store-type=PKCS12

(2)腾讯云配置 .jks

#项目端口号和请求路径
server.port=10006
server.servlet.context-path=/xxx-wx-server
#配置证书
server.ssl.key-store=classpath:xxxAbcxxx.com.jks
server.ssl.key-store-password=xxxxxxxxxxxxxxxx
server.ssl.key-store-type=JKS

3、启动类代码补充

一般来说springboot启动类里面配置http重定向https的配置代码即可,再没有什么别的代码配置;

package com.xxx;

import java.net.InetAddress;
import java.net.UnknownHostException;

import org.apache.catalina.Context;
import org.apache.catalina.connector.Connector;
import org.apache.tomcat.util.descriptor.web.SecurityCollection;
import org.apache.tomcat.util.descriptor.web.SecurityConstraint;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration;
import org.springframework.boot.web.embedded.tomcat.TomcatServletWebServerFactory;
import org.springframework.boot.web.servlet.server.ServletWebServerFactory;
import org.springframework.context.ConfigurableApplicationContext;
import org.springframework.context.annotation.Bean;
import org.springframework.core.env.Environment;

/**
 * 启动程序
 */
@SpringBootApplication
@ServletComponentScan
public class XxxApplication
{
    public static void main(String[] args) throws UnknownHostException
    {
        ConfigurableApplicationContext application = SpringApplication.run(XxxApplication.class, args);
    }
    
    /**
     * http重定向到https
     * @return
     */
    @Bean
    public ServletWebServerFactory servletContainer() {
        TomcatServletWebServerFactory tomcat = new TomcatServletWebServerFactory() {
            @Override
            protected void postProcessContext(Context context) {
                SecurityConstraint securityConstraint = new SecurityConstraint();
                securityConstraint.setUserConstraint("CONFIDENTIAL");
                SecurityCollection collection = new SecurityCollection();
                collection.addPattern("/*");
                securityConstraint.addCollection(collection);
                context.addConstraint(securityConstraint);
            }
        };
        tomcat.addAdditionalTomcatConnectors(redirectConnector());
        return tomcat;
    }

    private Connector redirectConnector() {
        Connector connector = new Connector(TomcatServletWebServerFactory.DEFAULT_PROTOCOL);
        connector.setScheme("http");
        //Connector监听的http的端口号
        connector.setPort(8008);
        connector.setSecure(false);
        //监听到http的端口号后转向到的https的端口号
        connector.setRedirectPort(8088);
        return connector;
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

cgv3

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值