SpringBoot配置http和https

1、修改application.yml

http:
  port: 8289
server:
  port: 8443
  tomcat:
    max-http-header-size: 8192
  ssl:
    key-store: classpath:tomcat.keystore
    key-password: 123456
    key-store-type: JKS
    key-alias: tomcat

2、添加HttpsConfig文件

import org.apache.catalina.Context;
import org.apache.catalina.connector.Connector;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.web.embedded.tomcat.TomcatServletWebServerFactory;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

/**
 * @author 
 * @date 2019-11-27 17:39
 * @Description:
 */
@Configuration
public class HttpsConfig {
    @Value("${http.port}")
    private int httpPort;

    @Value("${server.port}")
    private int serverPort;

    @Bean
    public TomcatServletWebServerFactory servletContainer() {
        TomcatServletWebServerFactory tomcat = new TomcatServletWebServerFactory () {
            @Override
            protected void postProcessContext(Context context) {
                // 如果要强制同时使用https和http,请松开以下注释
               /* SecurityConstraint securityConstraint = new SecurityConstraint();
                securityConstraint.setUserConstraint("CONFIDENTIAL");
                SecurityCollection collection = new SecurityCollection();
                collection.addPattern("/*");
                securityConstraint.addCollection(collection);
                context.addConstraint(securityConstraint);*/
            }
        };
        tomcat.addAdditionalTomcatConnectors(httpConnector());
        return tomcat;
    }

    @Bean
    public Connector httpConnector() {
        // 默认协议为org.apache.coyote.http11.Http11NioProtocol
        //Connector connector = new Connector("org.apache.coyote.http11.Http11NioProtocol");
        Connector connector = new Connector(TomcatServletWebServerFactory.DEFAULT_PROTOCOL);
        connector.setScheme("http");
        connector.setPort(httpPort);
        connector.setSecure(false);
        connector.setRedirectPort(serverPort);
        return connector;
    }
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Spring Boot中配置Minio的HTTPS访问,您需要完成以下步骤: 1. 生成自签名证书 使用以下命令生成自签名证书: ``` keytool -genkeypair -alias mycert -keyalg RSA -keysize 2048 -storetype PKCS12 -keystore keystore.p12 -validity 3650 -ext SAN=dns:localhost,ip:127.0.0.1 ``` 其中,`-ext SAN=dns:localhost,ip:127.0.0.1` 表示将 `localhost` 和 `127.0.0.1` 添加到证书的 SAN(Subject Alternative Name)字段中。 2. 在application.properties中配置Minio 在 `application.properties` 文件中添加以下配置: ``` # Minio配置 minio.endpoint=http://localhost:9000 minio.accessKey=accesskey minio.secretKey=secretkey minio.secure=true minio.ssl.trustStore=classpath:keystore.p12 minio.ssl.trustStorePassword=changeit minio.region=us-east-1 ``` 其中,`minio.secure=true` 表示启用HTTPS协议,`minio.ssl.trustStore` 和 `minio.ssl.trustStorePassword` 分别指定证书存储路径和密码。 3. 使用MinioClient 使用MinioClient连接到Minio服务器: ```java import io.minio.MinioClient; import io.minio.errors.MinioException; public class MinioDemo { public static void main(String[] args) throws MinioException { // 使用MinioClient连接到Minio服务器 MinioClient client = new MinioClient("https://localhost:9000", "accesskey", "secretkey"); // 列出所有存储桶 for (Bucket bucket : client.listBuckets()) { System.out.println(bucket.name()); } } } ``` 以上就是配置Minio的HTTPS访问的步骤,希望可以帮助到您。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值