SpringBoot2.0之后,启用https协议的方式与1.*时有点儿不同,贴一下代码。

  我的代码能够根据配置参数中的condition.http2https,确定是否启用https协议,如果启用https协议时,会将所有http协议的访问,自动转到https协议上。

一、启动程序

  1. package com.wallimn.iteye.sp.asset;
  2. import org.apache.catalina.Context;
  3. import org.apache.catalina.connector.Connector;
  4. import org.apache.tomcat.util.descriptor.web.SecurityCollection;
  5. import org.apache.tomcat.util.descriptor.web.SecurityConstraint;
  6. import org.springframework.beans.factory.annotation.Value;
  7. import org.springframework.boot.SpringApplication;
  8. import org.springframework.boot.autoconfigure.SpringBootApplication;
  9. import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
  10. import org.springframework.boot.web.embedded.tomcat.TomcatServletWebServerFactory;
  11. import org.springframework.context.annotation.Bean;
  12. /**
  13. * SpringBoot2.0启动程序
  14. * @author wallimn,http://wallimn.iteye.com
  15. *
  16. */
  17. @SpringBootApplication
  18. public class AssetApplication {
  19. public static void main(String[] args) {
  20. SpringApplication.run(AssetApplication.class, args);
  21. }
  22. //如果没有使用默认值80
  23. @Value("${http.port:80}")
  24. Integer httpPort;
  25. //正常启用的https端口 如443
  26. @Value("${server.port}")
  27. Integer httpsPort;
  28. // springboot2 写法
  29. @Bean
  30. @ConditionalOnProperty(name="condition.http2https",havingValue="true", matchIfMissing=false)
  31. public TomcatServletWebServerFactory servletContainer() {
  32. TomcatServletWebServerFactory tomcat = new TomcatServletWebServerFactory() {
  33. @Override
  34. protected void postProcessContext(Context context) {
  35. SecurityConstraint constraint = new SecurityConstraint();
  36. constraint.setUserConstraint("CONFIDENTIAL");
  37. SecurityCollection collection = new SecurityCollection();
  38. collection.addPattern("/*");
  39. constraint.addCollection(collection);
  40. context.addConstraint(constraint);
  41. }
  42. };
  43. tomcat.addAdditionalTomcatConnectors(httpConnector());
  44. return tomcat;
  45. }
  46. @Bean
  47. @ConditionalOnProperty(name="condition.http2https",havingValue="true", matchIfMissing=false)
  48. public Connector httpConnector() {
  49. System.out.println("启用http转https协议,http端口:"+this.httpPort+",https端口:"+this.httpsPort);
  50. Connector connector = new Connector("org.apache.coyote.http11.Http11NioProtocol");
  51. connector.setScheme("http");
  52. //Connector监听的http的端口号
  53. connector.setPort(httpPort);
  54. connector.setSecure(false);
  55. //监听到http的端口号后转向到的https的端口号
  56. connector.setRedirectPort(httpsPort);
  57. return connector;
  58. }}

二、配置文件

1.使用http协议时的配置 
server.port=80

2.使用https及http协议时的配置 
server.port=443 
server.ssl.key-store=classpath:keystore.p12 
server.ssl.key-store-password=your-password 
server.ssl.keyStoreType=PKCS12 
server.ssl.keyAlias=your-cert-alias 
condition.http2https=true 
http.port=80

pringBoot2.0启用https协议的更多相关文章

  1. 【转】Tomcat启用HTTPS协议配置过程

    转载请注明出处: http://blog.csdn.net/gane_cheng/article/details/53001846 http://www.ganecheng.tech/blog/530 ...

  2. Tomcat启用HTTPS协议配置过程

    Article1较为简洁,Article2较为详细,测试可行. Article1 概念简介 Tomcat 服务器是一个免费的开放源代码的Web 应用服务器,属于轻量级应用服务器,在中小型系统和并发访问 ...

  3. 启用https协议的方法

    提醒:启用https协议会降低服务器性能,如非必要不必启用 一.用openssl生成密钥.证书: 1.生成RSA密钥的方法 openssl genrsa -out privkey.pem 2048 建 ...

  4. mod_cluster启用https协议的步骤

    1.生成SSL证书与私钥 Generate Private Key on the Server Running Apache + mod_ssl First, generate a private k ...

  5. JBoss集群中启用HTTPS协议

    Generate server certificate Note: If you already have certificate created then this section can be i ...

  6. 4、Tomcat启用HTTPS协议配置

    一.本地模拟 1.安装jdk,自行百度安装教程 2.打开mac终端,输入命令 keytool -genkeypair -alias "证书名字" -keyalg "RSA ...

  7. IIS中如何应用程序启用https协议

    首先已经安装完了SSL证书 1.找到需要添加的站点,右击 ---> 编辑绑定-->添加--->选择  ""https"-->选择"SSL ...

  8. 阿里云服务器IIS启用HTTPS协议(转)

    https://www.cnblogs.com/randytech/p/7017188.html

  9. tomcat 启用https协议

    利用tomcat服务器配置https双向认证. 1.为服务器生成证书 打开cmd,进入jdk的bin目录下,输入下面的命令: keytool -genkey -v -alias tomcat -key ...

随机推荐

  1. LODOP关联后眉脚条码的遮挡的一种情况

    前面的博文中,有介绍层级关系,最先输出的打印项在下层,后输出的在上层,但是最近发现了一种例外,就是前面有关联的情况下,后面把一个条码设置为页眉页脚项,眉脚项和前面关联其他的项的那个项位置重合,虽然这个 ...

  2. RSA算法理解

    RSA加密算法是最常用的非对称加密算法,CFCA在证书服务中离不了它.但是有不少新来的同事对它不太了解,恰好看到一本书中作者用实例对它进行了简化而生动的描述,使得高深的数学理论能够被容易地理解.我们经 ...

  3. Appium移动自动化测试-----(六)1.appium-desktop下载安装

    Appium 移动测试中有个很重新的组件 Appium-Server,它主要用来监听我们的移动设备(真机或模拟器),然将不同编程语言编写的 appium 测试脚本进行解析,然后,驱动移动设备来运行测试 ...

  4. java properties文件转义字符和中文乱码解决

    properties文件的分隔符是   =或者 : 第一次出现的就是分割符,第二次出现的也不需要转义,也即是(忽略掉[],只是着重描述字符) [\=]     [\:]   或者  [=]  [:] ...

  5. 035 Android Volley框架进行网络请求

    1.volley入门介绍 开发Android应用的时候不可避免地都需要用到网络技术,而多数情况下应用程序都会使用HTTP协议来发送和接收网络数据.Android系统中主要提供了两种方式来进行HTTP通 ...

  6. python学习-57 logging模块

    logging 1.basicConfig方式 import logging # 以下是日志的级别 logging.debug('debug message') logging.info('info ...

  7. WUSTOJ 1347: GCD(Java)互质

    题目链接:1347: GCD Description 已知gcd(a,b)表示a,b的最大公约数. 现在给你一个整数n,你的任务是在区间[1,n)里面找到一个最大的x,使得gcd(x,n)等于1. I ...

  8. unittest之makeSuite\testload\discover及测试报告teseReport

    转载:http://www.cnblogs.com/sunny0/p/7771089.html 测试套件suite除了使用addTest以外,还有使用操作起来更更简便的makeSuite\testlo ...

  9. Vue使用指南(二)

    '''1.指令 ***** 文本指令 属性指令 方法(事件)指令 表单指令 条件指令 循环指令 2.组件 *** 局部组件 全局组件 父子组件间的交互''' 文件指令 <body> < ...

  10. Authorization

    授权,也叫访问控制,即在应用中控制谁访问哪些资源(如访问页面/编辑数据/页面操作等).在授权中需了解的几个关键对象:主体(Subject).资源(Resource).权限(Permission).角色 ...