查看: 3201|回复: 0

[Java代码] spring boot实战之内嵌容器tomcat配置

发表于 2018-3-4 10:27:47

本文介绍了spring boot实战之内嵌容器tomcat配置,分享给大家,具体如下:

默认容器

spring boot默认web程序启用tomcat内嵌容器tomcat,监听8080端口,servletPath默认为 / 通过需要用到的就是端口、上下文路径的修改,在spring boot中其修改方法及其简单;

在资源文件中配置:

  1. server.port=9090
  2. server.contextPath=/lkl
复制代码

启动spring boot

  1. 2015-10-04 00:06:55.768 INFO 609 --- [ main] o.s.w.s.handler.SimpleUrlHandlerMapping : Mapped URL path [/**/favicon.ico] onto handler of type [class org.springframework.web.servlet.resource.ResourceHttpRequestHandler]
  2. 2015-10-04 00:06:55.844 INFO 609 --- [ main] o.s.j.e.a.AnnotationMBeanExporter : Registering beans for JMX exposure on startup
  3. 2015-10-04 00:06:55.928 INFO 609 --- [ main] s.b.c.e.t.TomcatEmbeddedServletContainer : Tomcat started on port(s): 9090 (http)
  4. 2015-10-04 00:06:55.930 INFO 609 --- [ main] com.lkl.springboot.Application : Started Application in 3.906 seconds (JVM running for 4.184)
复制代码

可以看出其监听端口9090,执行 http://localhost:9090/lkl/springboot/liaokailin 成功访问

自定义tomcat

在实际的项目中简单的配置tomcat端口肯定无法满足大家的需求,因此需要自定义tomcat配置信息来灵活的控制tomcat。

以定义默认编码为例

  1. package com.lkl.springboot.container.tomcat;
  2. import org.springframework.boot.context.embedded.EmbeddedServletContainerFactory;
  3. import org.springframework.boot.context.embedded.tomcat.TomcatEmbeddedServletContainerFactory;
  4. import org.springframework.context.annotation.Bean;
  5. import org.springframework.context.annotation.Configuration;
  6. /**
  7. * tomcat 配置
  8. * @author liaokailin
  9. * @version $Id: TomcatConfig.java, v 0.1 2015年10月4日 上午12:11:47 liaokailin Exp $
  10. */
  11. @Configuration
  12. public class TomcatConfig {
  13. @Bean
  14. public EmbeddedServletContainerFactory servletContainer() {
  15. TomcatEmbeddedServletContainerFactory tomcat = new TomcatEmbeddedServletContainerFactory();
  16. tomcat.setUriEncoding("UTF-8");
  17. return tomcat;
  18. }
  19. }
复制代码

构建EmbeddedServletContainerFactory的bean,获取到TomcatEmbeddedServletContainerFactory实例以后可以对tomcat进行设置,例如这里设置编码为UTF-8

SSL配置

生成证书

  1. keytool -genkey -alias springboot -keyalg RSA -keystore /Users/liaokailin/software/ca1/keystore
  2. 设置密码123456
复制代码

tomcat中验证证书是否正确

修改tomcat/conf/server.xml文件

  1. <Connector
  2. protocol="org.apache.coyote.http11.Http11NioProtocol"
  3. port="8443" maxThreads="200"
  4. scheme="https" secure="true" SSLEnabled="true"
  5. keystoreFile="/Users/liaokailin/software/ca1/keystore" keystorePass="123456"
  6. clientAuth="false" sslProtocol="TLS"/>
复制代码

启动tomcat ,访问 http://localhost:8443

spring boot 内嵌tomcat ssl

配置资源文件

  1. server.port=8443
  2. server.ssl.enabled=true
  3. server.ssl.keyAlias=springboot
  4. server.ssl.keyPassword=123456
  5. server.ssl.keyStore=/Users/liaokailin/software/ca1/keystore
复制代码
  1. server.ssl.enabled 启动tomcat ssl配置
  2. server.ssl.keyAlias 别名
  3. server.ssl.keyPassword 密码
  4. server.ssl.keyStore 位置

启动 spring boot

访问https://localhost:8443/springboot/helloworld

多端口监听配置

前面启动ssl后只能走https,不能通过http进行访问,如果要监听多端口,可采用编码形式实现。

1.注销前面ssl配置,设置配置 server.port=9090

2.修改TomcatConfig.java

  1. package com.lkl.springboot.container.tomcat;
  2. import java.io.File;
  3. import org.apache.catalina.connector.Connector;
  4. import org.apache.coyote.http11.Http11NioProtocol;
  5. import org.springframework.boot.context.embedded.EmbeddedServletContainerFactory;
  6. import org.springframework.boot.context.embedded.tomcat.TomcatEmbeddedServletContainerFactory;
  7. import org.springframework.context.annotation.Bean;
  8. import org.springframework.context.annotation.Configuration;
  9. /**
  10. * tomcat 配置
  11. * @author liaokailin
  12. * @version $Id: TomcatConfig.java, v 0.1 2015年10月4日 上午12:11:47 liaokailin Exp $
  13. */
  14. @Configuration
  15. public class TomcatConfig {
  16. @Bean
  17. public EmbeddedServletContainerFactory servletContainer() {
  18. TomcatEmbeddedServletContainerFactory tomcat = new TomcatEmbeddedServletContainerFactory();
  19. tomcat.setUriEncoding("UTF-8");
  20. tomcat.addAdditionalTomcatConnectors(createSslConnector());
  21. return tomcat;
  22. }
  23. private Connector createSslConnector() {
  24. Connector connector = new Connector("org.apache.coyote.http11.Http11NioProtocol");
  25. Http11NioProtocol protocol = (Http11NioProtocol) connector.getProtocolHandler();
  26. try {
  27. File truststore = new File("/Users/liaokailin/software/ca1/keystore");
  28. connector.setScheme("https");
  29. protocol.setSSLEnabled(true);
  30. connector.setSecure(true);
  31. connector.setPort(8443);
  32. protocol.setKeystoreFile(truststore.getAbsolutePath());
  33. protocol.setKeystorePass("123456");
  34. protocol.setKeyAlias("springboot");
  35. return connector;
  36. } catch (Exception ex) {
  37. throw new IllegalStateException("cant access keystore: [" + "keystore" + "] ", ex);
  38. }
  39. }
  40. }
复制代码

通过addAdditionalTomcatConnectors方法添加多个监听连接;此时可以通过http 9090端口,https 8443端口。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持程序员之家。



回复

使用道具 举报