Tomcat 源码运行

210 阅读1分钟

Tomcat 源码下载

直接去 Tomcat 的官网下载源码即可,我下载的是 8.5.59 版本。

IDEA运行源码

解压后的源码在 idea 中打开,并在文件夹根目录下新建 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>Tomcat8.5</artifactId>
    <name>Tomcat8.5</name>
    <version>8.5</version>
 
    <build>
        <finalName>Tomcat8.5</finalName>
        <sourceDirectory>java</sourceDirectory>
        <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>

然后右键 pom.xm l选择“Add As Maven Project”,这样就以 Maven 的方式导入了 Tomcat 项目。

在根目录下新建 catalina-home 文件夹,并将 conf 和 webapps 文件夹移动到 catalina-home 目录中

配置应用启动

新建 Application,Main class 设置为 Tomcat 的启动类:org.apache.catalina.startup.Bootstrap,增加 VM 参数:

-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

启动设置

点击运行按钮就可以启动 Tomcat 了。虽然 Tomcat 启动起来了,但是我们会发现控制台输出的内容为乱码。

日志乱码

我们打开 org.apache.tomcat.util.res.StringManager 类,修改“getString(String key)”方法,增加对字符串的编码转换,再启动 Tomcat 发现编码就恢复正常了

if (Objects.nonNull(str)) {
    str = new String(str.getBytes(StandardCharsets.ISO_8859_1), StandardCharsets.UTF_8);
}

但当我们打开 Tomcat 的管理后台时候,发现依然会出现乱码情况。

管理页乱码

这里我们需要打开 org.apache.jasper.compiler.Localizer 类,修改“getMessage(String errCode)”方法,同样使用上面的代码,增加对字符串的编码转换。

再次打开管理后台的时候,会看到完整的错误信息。

原因是我们直接启动 org.apache.catalina.startup.Bootstrap 的时候没有加载org.apache.jasper.servlet.JasperInitializer,从而无法编译 JSP。解决办法是在 Tomcat 的源码org.apache.catalina.startup.ContextConfig 中的 configureStart() 函数中手动将 JSP 解析器初始化:

protected synchronized void configureStart() {
    ......

    webConfig();
    // 增加的解析器
    context.addServletContainerInitializer(new JasperInitializer(), null);

    ......
}

再次打开管理页面就可以看到我们熟悉的 Tomcat 管理页面。

管理页

IDEA运行tomcat8.5.35源代码 tomcat源码启动时乱码问题