Springboot工程配置ssl证书,实现tomcat开放http&https多端口访问

此文简单概述Springboot工程中配置ssl证书,不做其他概述。

配置前提,需要现在腾讯云或者阿里云等其他正规渠道购买ssl证书。先将后缀未jks的证书下载到本地,如果未设置密码,那么在下载的压缩包内会携带一个临时key的文件(临时密码)。

  • 1、将后缀为jks的证书文件引到根目录的resource目录下
    在这里插入图片描述
  • 2、在application.yml配置文件中配置ssl
    在这里插入图片描述

完成以上两步后,ssl 证书已经配置完成,启动后可看到通信协议变成了https的方式了。
==》接下来的操作是实现tomcat开放多个类型端口的方式:
同时使用http & https 方式进行访问。(在springboot启动类中加入两个bean对象!一定是要在springboot主启动类中)

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.web.embedded.tomcat.TomcatServletWebServerFactory;
import org.springframework.context.annotation.Bean;


	@Bean
    public TomcatServletWebServerFactory tomcatServletWebServerFactory( ){
        TomcatServletWebServerFactory factory = new TomcatServletWebServerFactory(){
            @Override
            protected void postProcessContext(Context context) {
                SecurityConstraint securityConstraint = new SecurityConstraint();
                securityConstraint.setUserConstraint("CONFIDENTIAL");
                SecurityCollection securityCollection = new SecurityCollection();
                securityCollection.addPattern("/*");
                securityConstraint.addCollection(securityCollection);
                context.addConstraint(securityConstraint);
            }
        };
        factory.addAdditionalTomcatConnectors(httpConnector());
        return factory;
    }

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

==ok!==到此结束。

  • 11
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 你可以在 application.yml 文件中使用以下配置来设置 MySQL 的 SSH 通道: ``` spring: datasource: url: jdbc:mysql://${MYSQL_HOST}:${MYSQL_PORT}/${MYSQL_DATABASE} username: ${MYSQL_USER} password: ${MYSQL_PASSWORD} jdbcUrl: jdbc:mysql://${MYSQL_HOST}:${MYSQL_PORT}/${MYSQL_DATABASE}?useSSL=false ssh: host: ${SSH_HOST} port: ${SSH_PORT} user: ${SSH_USER} password: ${SSH_PASSWORD} privateKey: ${SSH_PRIVATE_KEY} passphrase: ${SSH_PASSPHRASE} ``` 这里的 ${MYSQL_HOST}、${MYSQL_PORT}、${MYSQL_DATABASE}、${MYSQL_USER} 和 ${MYSQL_PASSWORD} 分别对应 MySQL 服务器的主机名、端口、数据库名、用户名和密码。 ${SSH_HOST}、${SSH_PORT}、${SSH_USER}、${SSH_PASSWORD}、${SSH_PRIVATE_KEY} 和 ${SSH_PASSPHRASE} 分别对应 SSH 代理服务器的主机名、端口、用户名、密码、私钥文件路径和私钥的密码(如果有的话)。 请注意,在使用上述配置之前,你需要确保你已经安装并配置了 MySQL 和 SSH 代理服务器,并且你的应用程序能够访问这些服务器。 ### 回答2: 在application.yml配置MySQL的SSH通道需要以下几步: 1. 将SSH证书保存到本地。首先,需要通过SSH连接到MySQL服务器。为此,我们需要一个SSH证书,这个证书文件通常以.pem或.ppk结尾。将该证书保存在本地。 2. 在application.yml配置SSH连接参数。在yml文件中,需要设置SSH连接的主机、端口、用户名、密码和证书路径。以下是一个示例配置: ```yml spring: datasource: url: jdbc:mysql://localhost:3306/database_name?useSSL=false&allowPublicKeyRetrieval=true&serverTimezone=UTC # MySQL连接地址,使用SSH通道,需要指定SSH的本地端口号 username: your_username # MySQL数据库用户名 password: your_password # MySQL数据库密码 ssh: enabled: true # 启用SSH通道 host: ssh_host # SSH服务器地址 port: 22 # SSH服务器端口号 username: ssh_username # SSH用户名 password: ssh_password # SSH密码 key-file: path/to/ssh_key.pem # SSH证书的本地路径 ``` 请将其中的`database_name`,`your_username`,`your_password`,`ssh_host`,`ssh_username`,`ssh_password`和`path/to/ssh_key.pem`替换为正确的值。 3. 添加MySQL连接驱动依赖。在项目的pom.xml文件中,确保已添加正确的MySQL连接驱动依赖。以下是一个示例配置: ```xml <dependencies> <!-- 其他依赖 --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.23</version> </dependency> </dependencies> ``` 请将`<version>8.0.23</version>`替换为您使用的MySQL连接驱动的版本号。 通过以上步骤,您可以在application.yml中成功配置MySQL的SSH通道。记得替换相应的参数值,并按需修改其他数据库相关的配置。 ### 回答3: 在application.yml配置文件中配置MySQL的SSH通道,可以通过如下步骤进行配置: 1. 首先,在application.yml中添加MySQL数据库相关的配置信息,包括数据库的host、port、username、password等信息。 例如: ``` spring: datasource: url: jdbc:mysql://localhost:3306/mydatabase username: root password: mypassword driver-class-name: com.mysql.jdbc.Driver ``` 2. 然后,在application.yml中添加SSH通道的配置信息,包括SSH的host、port、username、password等信息。 例如: ``` ssh: host: ssh.example.com port: 22 username: root password: sshpassword ``` 3. 接下来,配置SSH隧道的本地转发规则。通过配置本地端口和目标数据库地址(即MySQL的host和port),将本地请求转发到远程服务器。 例如: ``` ssh: local-port-forwarding: - local-port: 3307 remote-host: localhost remote-port: 3306 ``` 这表示将本地的3307端口转发到远程服务器的localhost:3306上。 4. 最后,通过配置Spring Boot的数据源,将SSH通道应用到数据库连接上。 例如: ``` spring: datasource: url: jdbc:mysql://localhost:3307/mydatabase username: root password: mypassword driver-class-name: com.mysql.jdbc.Driver ``` 配置完成后,应用程序将通过SSH通道连接到远程MySQL数据库。这样,应用程序就可以访问和操作远程MySQL数据库了。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值