首页 > 编程语言 >idea调试tomcat源码

idea调试tomcat源码

时间:2022-08-22 20:59:13浏览次数:92  
标签:java tomcat idea 源码 jasper apache org servlet

优化Tomcat AJP 误报时有一些疑问,调试一下

1 下载tomcat

历史版本列表:https://archive.apache.org/dist/tomcat/tomcat-8/
源码文件夹:https://archive.apache.org/dist/tomcat/tomcat-8/v8.5.50/src/
下载apache-tomcat-8.5.50-src.zip
解压一下

2 导入pom.xml

在源码根目录下新建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.0</artifactId>
    <name>Tomcat8.0</name>
    <version>8.0</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.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>

3 idea打开/配置/运行

(1 idea打开源码路径
(2 配置JDK: File -> Project Structure
image.png
(3 新建configurations
新增application,并指向tomcat 入口 "Bootstrap"
image.png

4 运行解决报错

(1 报错一 测试类报错

/apache-tomcat-8.5.50-src/test/util/TestCookieFilter.java:29:36
java: 找不到符号
  符号:   变量 CookieFilter
  位置: 类 util.TestCookieFilter

解决:
注释整个/apache-tomcat-8.5.50-src/test/util/TestCookieFilter.java文件

(2 报错二 解析报错

Type Exception Report

Message java.lang.NullPointerException

Description The server encountered an unexpected condition that prevented it from fulfilling the request.

Exception

org.apache.jasper.JasperException: java.lang.NullPointerException
	org.apache.jasper.servlet.JspServletWrapper.handleJspException(JspServletWrapper.java:598)
	org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:514)
	org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:386)
	org.apache.jasper.servlet.JspServlet.service(JspServlet.java:330)
	javax.servlet.http.HttpServlet.service(HttpServlet.java:741)
Root Cause

java.lang.NullPointerException
	org.apache.jsp.index_jsp._jspService(index_jsp.java:424)
	org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70)
	javax.servlet.http.HttpServlet.service(HttpServlet.java:741)
	org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:476)
	org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:386)
	org.apache.jasper.servlet.JspServlet.service(JspServlet.java:330)
	javax.servlet.http.HttpServlet.service(HttpServlet.java:741)
Note The full stack trace of the root cause is available in the server logs.

image.png

解决:
位置:

  • 文件:/apache/catalina/startup/ContextConfig.java
  • 类:protected synchronized void configureStart()
  • 具体位置:webConfig(); 下方

image.png
添加代码

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

并添加引用
image.png

5 正常运行

image.png
image.png

参考链接
pom.xml 出处:https://blog.csdn.net/wangjunjie0817/article/details/102944338
报错2处理:https://www.jianshu.com/p/3b6b393062cc
搭建:https://blog.csdn.net/Dyoungwhite/article/details/122085305

标签:java,tomcat,idea,源码,jasper,apache,org,servlet
From: https://www.cnblogs.com/huim/p/16614196.html

相关文章

  • IDEA 自动生成快捷键
    1.IDEA自带的快捷键自动生成main()函数:打出main后回车输出打印:打出sout后回车复制当前行:光标在当前行,Ctrl+C复制当前行到下一行:Ctrl+D自动生成构造函......
  • 大家都能看得懂的源码 - 封装一个管理 url 状态的 hook
    本文是深入浅出ahooks源码系列文章的第十一篇,该系列已整理成文档-地址。觉得还不错,给个star支持一下哈,Thanks。本文来讲下ahooks中的useUrlState。通过urlquer......
  • IDEA快捷键相关
    1./+shift**+Enter会出现以下这种注释文档注释12.选中ctrl+/加//注释或取消//注释单行3.选中ctrl+shift+/加/*/注释或取消/*/文档注释2......
  • IDEA新建项目的坑
    今天新建项目时,发现了一个很有意思的问题。即如果你新建了一个文件夹,再在IDEA里面新建项目、选择该文件夹时,IDEA会自动把该文件夹转化为模块。例如上图中,DemoProject是我......
  • idea集成maven插件和使用骨架创建maven的java工程
    idea集成maven插件     关闭设置界面   使用骨架创建maven的java工程     ......
  • 修改Tomcat启动窗口的名称
    打开Tomcat的bin目录下的Catalina.bat,找到这一属性块:doStartshiftif"%TITLE%"==""setTITLE=projecNameset_EXECJAVA=start"%TITLE%"%_RUNJAVA%ifnot""%1"......
  • Maven概念模型图和idea集成Maven
    Maven概念模型图   idea集成Maven在IDEA外部点击设置进行配置-DarchetypeCatalog=internal     搜索复制......
  • 源码安装RocketMQ4.x可视化控制台详细教程
    下载源码https://github.com/apache/rocketmq-externals进入roccketmq-consolecdroccketmq-console编译打包mvncleanpackage-Dmaven.test.skip=true存在......
  • centos7下tomcat部署jenkins版本升级
    jenkins升级步骤war包下载地址https://www.jenkins.io/download/点击PastReleases,选择war版本1.将要升级指定版本的jenkins的war包下载并解压到tomcat的webapp目录下w......
  • Windows环境下IDEA配置SSH Key访问Gitlab源代码仓库
    使用Gitlab管理项目时,project在创建的时候只能选择“Public”公开状态,Private和Internal私有模式下不能使用http方式进行连接。(ssh方式在三种模式下都可以)。使用http方式直......