本文共 6831 字,大约阅读时间需要 22 分钟。
将tomcat作为应用的一部分集成到应用中,使得应用可以直接开启http服务,对外提供接口。此时应用程序不必再遵守j2ee中的文件目录格式要求。
此种方式改变了以往先部署tomcat容器,再按照j2ee标准目录格式部署应用的做法,简化了网络应用的部署工作,也方便了将现有模块功能网络化访问的需求。
pom.xml文件,其中使用了tomcat8.5.9版本,jdk1.8。
4.0.0 com.founder embed-tomcat 8.0.1-SNAPSHOT jar tomcat http://maven.apache.org UTF-8 8.5.9 junit junit 3.8.1 test org.apache.tomcat tomcat-util ${tomcat.version} org.apache.tomcat tomcat-servlet-api ${tomcat.version} org.apache.tomcat tomcat-juli ${tomcat.version} org.apache.tomcat tomcat-jsp-api ${tomcat.version} org.apache.tomcat tomcat-jdbc ${tomcat.version} org.apache.tomcat tomcat-jasper-el ${tomcat.version} org.apache.tomcat tomcat-jasper ${tomcat.version} org.apache.tomcat tomcat-i18n-ja ${tomcat.version} org.apache.tomcat tomcat-i18n-fr ${tomcat.version} org.apache.tomcat tomcat-i18n-es ${tomcat.version} org.apache.tomcat tomcat-el-api ${tomcat.version} org.apache.tomcat tomcat-dbcp ${tomcat.version} org.apache.tomcat tomcat-coyote ${tomcat.version} org.apache.tomcat tomcat-api ${tomcat.version} org.apache.tomcat tomcat-annotations-api ${tomcat.version} org.apache.tomcat tomcat-catalina-ws ${tomcat.version} org.apache.tomcat tomcat-catalina-ha ${tomcat.version} org.apache.tomcat tomcat-catalina-ant ${tomcat.version} org.apache.tomcat.embed tomcat-embed-core ${tomcat.version} org.apache.tomcat.embed tomcat-embed-jasper ${tomcat.version} org.apache.maven.plugins maven-compiler-plugin 2.1
public class TomcatStarter { public static void main(String[] args) throws LifecycleException { Tomcat tomcat = new Tomcat(); // tomcat.setBaseDir("/temp"); Server server = tomcat.getServer(); // server.setPort(8080); Service service = tomcat.getService(); service.setName("Tomcat-embbeded"); Connector connector = tomcat.getConnector(); // connector.setPort(8888); Context context = tomcat.addContext("", "/"); tomcat.addServlet("", "test", new MyServlet()); context.addServletMappingDecoded("/*", "test"); server.start(); server.await(); }}
因为Tomcat启动时,需要指定它的工作目录(此原因还未深究),所以在建立Tomcat实例后,使用
tomcat.setBaseDir("/temp");
设置此目录。如果为设置过此目录,则默认会是“tomcat.8080”。8080是tomcat实例中设置的port值,默认为8080。
此外此目录中,要确保有“webapps”目录(此原因还未深究)。
通过
tomcat.getServer();
可获得一个Server实例,并可以设置此server的port值,在此端口上监听server关闭请求。
通过
tomcat.getService();
可获得service实例,其真实类型为StandardService。
此service实际为上述创建的server中的service;
通过
tomcat.getConnector();
可获得一个connector实例,默认protocol为“HTTP/1.1”。
此connector实际上为上述创建的service中的connector。
connector.setPort(8888);
用于设置监听的端口,即http请求时访问的端口。
tomcat.addContext("", "/");
创建context时,会将默认的engine、host一同创建,因此在TomcatStarter中可以忽略其创建。
addContext中的两个参数分别是contextPath和docBase。
contextPath:即网络请求是的路径;
docBase:即在tomcatBaseDir/webapps目录下的目录,可以不包含任何文件,但必须存在(此原因还未深究)。
这里同server.xml中的配置相似。
tomcat.addServlet("", "test", new MyServlet());
用于向指定的context添加servlet。
context.addServletMappingDecoded("/*", "test");
用于完成servlet在context中的映射配置。
这里同web.xml中的配置相似。
注意:context的显示创建是不可以忽略的。
注意:service、connector、engine、host的显式创建可以忽略。
简化后的TomcatStarter可以为
public class TomcatStarter { public static void main(String[] args) throws LifecycleException { Tomcat tomcat = new Tomcat(); tomcat.setPort(8080); Context context = tomcat.addContext("", "/"); tomcat.addServlet("", "test", new MyServlet()); context.addServletMappingDecoded("/*", "test"); tomcat.start(); tomcat.getServer().await(); }}
server.start(); // 或者tomcat.start();server.await(); //或者tomcat.getServer().await();
转载地址:http://vpwci.baihongyu.com/