Tomcat源码环境搭建学习
- 下载tomcat及源码安装
下载8.5.57地址:https://tomcat.apache.org/download-80.cgi,本人Mac的,故下载tar.gz文件包。上面的红框为tomcat应用,下面的红框为tomcat的源码
-
解压及创建catalina-home目录
进入到存放目录,解压apache-tomcat-8.5.57-src.tar.gz为apache-tomcat-8.5.57-src文件目录,在apache-tomcat-8.5.57-src下创建catalina-home文件夹,并将目录下的conf和webapps复制到catalina-home下
备注:tar -zxvf apache-tomcat-8.5.57-src.tar.gz解压或其它解压软件解压
-
创建pom.xml,构建maven配置
Pom.xml的配置如下:
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>org.apache.tomcat</groupId> <artifactId>Tomcat</artifactId> <name>Tomcat</name> <version>8.5</version> <build> <finalName>Tomcat8.5</finalName> <sourceDirectory>java</sourceDirectory> <!--test 下的有些文件报错,因此将test文件夹去掉了--> <!--<testSourceDirectory>test</testSourceDirectory>--> <resources> <resource> <directory>java</directory> </resource> </resources> <testResources> <testResource> <directory>test</directory> </testResource> </testResources> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <version>2.3</version> <configuration> <encoding>UTF-8</encoding> <source>1.8</source> <target>1.8</target> </configuration> </plugin> </plugins> </build> <dependencies> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.12</version> <scope>test</scope> </dependency> <dependency> <groupId>org.easymock</groupId> <artifactId>easymock</artifactId> <version>3.4</version> </dependency> <dependency> <groupId>ant</groupId> <artifactId>ant</artifactId> <version>1.7.0</version> </dependency> <dependency> <groupId>wsdl4j</groupId> <artifactId>wsdl4j</artifactId> <version>1.6.2</version> </dependency> <dependency> <groupId>javax.xml</groupId> <artifactId>jaxrpc</artifactId> <version>1.1</version> </dependency> <dependency> <groupId>org.eclipse.jdt.core.compiler</groupId> <artifactId>ecj</artifactId> <version>4.5.1</version> </dependency> </dependencies> </project>
-
将项目导入idea中
open project --> 选中pom.xml–> 下载tomcat的依赖jar
项目结构如下: -
配置启动参数
VM options参数如下:
-Dcatalina.home=catalina-home
-Dcatalina.base=catalina-home
-Djava.endorsed.dirs=catalina-home/endorsed
-Djava.io.tmpdir=catalina-home/temp
-Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager
-Djava.util.logging.config.file=catalina-home/conf/logging.properties
6. 启动问题解决
A. 启动后控制台乱码
浏览器访问http://localhost:8080,出现乱码及报错信息
解决:
方法一:VM options增加 -Duser.country=EN 参数,只是将乱码显示成了英文,访问页面还是有乱码,未解决问题点。
方法二:参照博客做法,并稍做修改。
https://blog.csdn.net/zhoutaoping1992/article/details/104751705#comments
修改1:修改 org.apache.tomcat.util.res.StringManager的方法public String getString(final String key, final Object… args);新增如下代码:
try {
str=new String(str.getBytes("ISO-8859-1"),"UTF-8");
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
修改2:修改org.apache.jasper.compiler.Localizer的String getMessage(String errCode);新增如下代码:
try {
str=new String(str.getBytes("ISO-8859-1"),"UTF-8");
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
通过以上两个修改点只是解决部分中文乱码,未解决问题。修改1中的方法实际调用getString(String key)方法,只要在该方法中增加修改的点即可测地解决问题点。
至此,乱码问题解决
B. 接着访问http://localhost:8080报错
出现此报错
是启动org.apache.catalina.startup.Bootstrap的时候没有加载org.apache.jasper.servlet.JasperInitializer,从而无法编译JSP。
解决办法
是在tomcat的源码org.apache.catalina.startup.ContextConfig中的configureStart函数中手动将JSP解析器初始化:
添加代码:context.addServletContainerInitializer(new JasperInitializer(), null);
至此,tomcat8.5的源码环境搭建成功