Tomcat源码运行(一)

1、源码下载:http://archive.apache.org/dist/tomcat/tomcat-9/v9.0.33/src/

2、创建空项目:apache-tomcat

3、进入项目文件夹apache-tomcat解压源码包apache-tomcat-9.0.33-src.zip得到apache-tomcat-9.0.33-src文件夹

4、进入apache-tomcat-9.0.33-src文件夹,并创建一个目录,命名为home,并将conf、webapps目录移入home 目录中

5、在apache-tomcat-9.0.33-src文件夹下创建pom.xml文件,内容如下:

 1 <?xml version="1.0" encoding="UTF-8"?>
 2 <project xmlns="http://maven.apache.org/POM/4.0.0"
 3          xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 4          xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
 5 
 6     <modelVersion>4.0.0</modelVersion>
 7     <groupId>org.apache.tomcat</groupId>
 8     <artifactId>apache‐tomcat‐9.0.33‐src</artifactId>
 9     <name>Tomcat9.0</name>
10     <version>9.0</version>
11 
12     <build>
13         <finalName>Tomcat9.0</finalName>
14         <sourceDirectory>java</sourceDirectory>
15        <!-- <testSourceDirectory>test</testSourceDirectory>-->
16         <resources>
17             <resource>
18                 <directory>java</directory>
19             </resource>
20         </resources>
21 
22        <!-- <testResources>
23             <testResource>
24                 <directory>test</directory>
25             </testResource>
26         </testResources>-->
27         <plugins>
28             <plugin>
29                 <groupId>org.apache.maven.plugins</groupId>
30                 <artifactId>maven-compiler-plugin</artifactId>
31                 <version>3.5.1</version>
32                 <configuration>
33                     <encoding>UTF‐8</encoding>
34                     <source>1.8</source>
35                     <target>1.8</target>
36                 </configuration>
37             </plugin>
38         </plugins>
39     </build>
40     <dependencies>
41         <dependency>
42             <groupId>junit</groupId>
43             <artifactId>junit</artifactId>
44             <version>4.12</version>
45             <scope>test</scope>
46         </dependency>
47         <dependency>
48             <groupId>org.easymock</groupId>
49             <artifactId>easymock</artifactId>
50             <version>3.4</version>
51         </dependency>
52         <dependency>
53             <groupId>ant</groupId>
54             <artifactId>ant</artifactId>
55             <version>1.7.0</version>
56         </dependency>
57         <dependency>
58             <groupId>wsdl4j</groupId>
59             <artifactId>wsdl4j</artifactId>
60             <version>1.6.2</version>
61         </dependency>
62         <dependency>
63             <groupId>javax.xml</groupId>
64             <artifactId>jaxrpc</artifactId>
65             <version>1.1</version>
66         </dependency>
67         <dependency>
68             <groupId>org.eclipse.jdt.core.compiler</groupId>
69             <artifactId>ecj</artifactId>
70             <version>4.5.1</version>
71         </dependency>
72     </dependencies>
73 </project>
View Code

6.进入IDEA导入找到之前创建项目的目录 点击apache-tomcat-9.0.33-src目录下的pom.xml文件,进行导入

7.找到启动类Bootstrap,在 java/org/apache/catalina/startup下

8.配置启动类 Edit Configurations 进行配置启动类 并设置VM参数
   1. 选择 + Application
   2. 启动类名设置
   3. Main class选择      一直选择到Bootstrap类
   4. VM options设置     (更改以下1、3、4为你本机项目文件的位置)

    -Dcatalina.home=F:/IDEA_WorkSpace/itcast_tomcat/apache-tomcat-9.0.33-src/home
    -Dcatalina.base=F:/IDEA_WorkSpace/itcast_tomcat/apache-tomcat-9.0.33-src/home
    -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager
    -Djava.util.logging.config.file=F:/IDEA_WorkSpace/itcast_tomcat/apache-tomcat-9.0.33-src/home/conf/logging.properties

10、编译项目,可能会报错
    Error:(320, 45) java: 找不到符号
    符号: 变量 VERSION_9 、10、11、12
    位置: 类 org.eclipse.jdt.internal.compiler.impl.CompilerOptions
    统一将错误改为VERSION_1_8即可      (或者改为你项目的JDK版本  )
11、运行项目
  启动、运行成功;
12、为何控制台会有乱码:
  原因:一般是中文编码不匹配导致;经跟踪,发现是ResourceBundle读取org\apache\catalina\startup\LocalStrings_zh_CN.properties文件时没有用utf8解码导致;
  解决:修改org.apache.tomcat.util.res.StringManager类中的getString函数;
  由
  if (bundle != null) {
  str = bundle.getString(key);
  }
  改为
  if (bundle != null) {
  str = new String(bundle.getString(key).getBytes(“ISO-8859-1”), “UTF-8”);
  }
  再次运行,控制台无乱码.

13.访问页面,但是报500错误  

  原因:是我们直接启动org.apache.catalina.startup.Bootstrap的时候没有加载JasperInitializer,从而无法编译JSP。

  解决办法是在tomcat的源码ContextConfig中的configureStart函数中手动将JSP解析器初始化.

  解决:找到 java/org/apache/catalina/startup下   ContextConfig 这个类

  在configureStart()方法的webConfig();    (代码775行)下面加上

  

context.addServletContainerInitializer(new JasperInitializer(), null);

14.再次访问 ,成功

猜你喜欢

转载自www.cnblogs.com/zhaomo/p/12535872.html