tomcat源码运行

本文详细记录了如何下载并配置Tomcat源码,通过Maven进行管理,以及在IDEA中运行Tomcat的过程。在运行过程中遇到了JSP编译问题和日志乱码问题,通过修改源码和配置文件得以解决。最后,文章提供了修改后的解决方案,帮助读者更好地理解和学习Tomcat的工作原理。
摘要由CSDN通过智能技术生成

学习目标:

本文是转载的,只是学习记录下!

原文路径如下:https://www.cnblogs.com/wk-missQ1/p/13138720.html

运行tomcat源码,有助于理解tomcat原理,学习tomcat!

学习内容:

1、下载tomcat源码
2、运行tomcat

开始

1、下载tomcat

在这里插入图片描述

2、配置路径和文件

1)下载到一个文件夹下,如tomcatSource,apache-tomcat-8.5.68-src是tomcat解压文件,catalina-home是自己创建的,放置配置文件的
在这里插入图片描述
2)catalina-home文件夹下内容,标红的是直接从源码包复制过来的
在这里插入图片描述
3)tomcatSource文件夹下加入pom文件,内容如下:
在这里插入图片描述
pom:

<?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>gxf</groupId>
    <artifactId>apache-tomcat-8</artifactId>
    <name>apache-tomcat-8-source</name>
    <version>1.0</version>
    <packaging>pom</packaging>
    <modules>
        <module>apache-tomcat-8.5.68-src</module>
    </modules>
</project>

注意:配置好modele,指向你的源码包名字

4)apache-tomcat-8.5.68-src包下加入pom文件
在这里插入图片描述
pom内容:

<?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.68</artifactId>
    <name>Tomcat8.5.68</name>
    <version>8.5</version>


    <build>
        <finalName>Tomcat8.0</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.0.2</version>

                <configuration>
                    <encoding>UTF-8</encoding>
                    <source>1.8</source>
                    <target>1.8</target>
                </configuration>
            </plugin>
        </plugins>
    </build>

   <dependencies>
        <dependency>
            <groupId>org.easymock</groupId>
            <artifactId>easymock</artifactId>
            <version>3.5</version>
            <scope>test</scope>
        </dependency>

        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
            <scope>test</scope>
        </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.6.1</version>
        </dependency>
    </dependencies>
</project>

5)导入到idea中如下:
在这里插入图片描述
6)配置启动类
在这里插入图片描述
其中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

7)test类有出现包找不到的,我是把他给屏蔽了

8)启动tomcat
在这里插入图片描述
在浏览器运行:http://localhost:8080/出现错误
在这里插入图片描述
修改:
因为我们直接启动org.apache.catalina.startup.Bootstrap的时候没有加载org.apache.jasper.servlet.JasperInitializer,从而无法编译JSP。解决办法是:

打开文件:java/org/apache/catalina/startup/ContextConfig.java,找到webConfig();方法,在下面加上context.addServletContainerInitializer(new JasperInitializer(),null);
如下:
在这里插入图片描述

设置完毕:再次访问
在这里插入图片描述

9)日志乱码
打印日志乱码虽说不是大事,但是也比较恶心
原文参考:https://blog.csdn.net/zhoutaoping1992/article/details/104751705
修改两个地方,将默认编码ISO-8859-1变成UTF-8
第一个地方:修改StringManager类中getString
在这里插入图片描述
第二个地方,修改Localizer类中getMessage方法
在这里插入图片描述

        try{
            errMsg = new String(errMsg.getBytes("ISO-8859-1"),"UTF-8");
        }catch (Exception e){
            e.printStackTrace();
        }

本文是转载的,只是记录学习下!

原文路径如下:https://www.cnblogs.com/wk-missQ1/p/13138720.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值