调试前需确保系统已安装JDK(Java开发工具包)和Tomcat(JSP/Servlet容器),这是JSP运行的基础环境。
sudo apt update
sudo apt install openjdk-11-jdk
# 验证安装
java -version  # 应输出OpenJDK 11版本信息
sudo apt install tomcat9
# 启动Tomcat并设置开机自启
sudo systemctl start tomcat9
sudo systemctl enable tomcat9
# 验证Tomcat运行状态
sudo systemctl status tomcat9  # 应显示“active (running)”
需调整Tomcat配置以启用调试模式,允许IDE或调试工具连接。
web.xml文件(/etc/tomcat9/web.xml),找到<servlet>标签(对应org.apache.jasper.servlet.JspServlet),添加debug="true"参数:<servlet>
    <servlet-name>jsp</servlet-name>
    <servlet-class>org.apache.jasper.servlet.JspServlet</servlet-class>
    <init-param>
        <param-name>debug</param-name>
        <param-value>true</param-value>  <!-- 启用JSP调试 -->
    </init-param>
    <load-on-startup>3</load-on-startup>
</servlet>
保存后重启Tomcat:sudo systemctl restart tomcat9。/etc/tomcat9/catalina.sh),在文件开头添加以下JVM参数:export CATALINA_OPTS="-Xdebug -Xrunjdwp:transport=dt_socket,address=8000,server=y,suspend=n"
重启Tomcat使配置生效:sudo systemctl restart tomcat9。此时Tomcat会在8000端口监听调试连接。适用于快速定位简单问题(如变量值、流程分支)。
<% %>脚本片段中添加输出语句:<%
    int a = 10;
    int b = 20;
    int sum = a + b;
    System.out.println("【调试】a+b的和为:" + sum);  // 输出到Tomcat日志
%>
/var/log/tomcat9/catalina.out,使用tail命令实时查看:tail -f /var/log/tomcat9/catalina.out
适用于复杂项目,可实现日志分级(DEBUG/INFO/ERROR)、输出到文件等。
pom.xml中添加):<dependency>
    <groupId>log4j</groupId>
    <artifactId>log4j</artifactId>
    <version>1.2.17</version>
</dependency>
log4j.properties(放在WEB-INF/classes目录下):log4j.rootLogger=DEBUG, stdout, file
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} [%t] %-5p %c{1}:%L - %m%n
log4j.appender.file=org.apache.log4j.RollingFileAppender
log4j.appender.file.File=/var/log/tomcat9/myapp-debug.log
log4j.appender.file.MaxFileSize=10MB
log4j.appender.file.MaxBackupIndex=5
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} [%t] %-5p %c{1}:%L - %m%n
<%@ page import="org.apache.log4j.Logger" %>
<%
    Logger logger = Logger.getLogger("myapp");
    logger.debug("【Log4j调试】用户登录成功");  // 输出到myapp-debug.log
%>
适用于复杂项目,支持断点、单步执行、变量监视等高级功能。
Run > Edit Configurations,点击+添加Remote JVM Debug。8000(与Tomcat配置一致),名称改为“Tomcat Debug”。Debug按钮启动调试会话。Run > Debug Configurations,双击Remote Java Application创建新配置。localhost)和端口(8000),点击Apply后点击Debug。http://localhost:8080/your-app/test.jsp)。IDE会捕获断点,进入调试模式,可查看变量值、执行流程等。/var/log/tomcat9/catalina.out(标准输出)和/var/log/tomcat9/localhost.yyyy-mm-dd.log(应用日志),包含JSP编译错误、运行时异常等信息。F12打开,查看Console(控制台)中的JavaScript错误和Network(网络)中的请求响应状态(如404、500错误)。/var/log/tomcat9/myapp-debug.log),获取更详细的业务逻辑调试信息。CATALINA_OPTS中的调试参数),避免安全风险。System.out.println(),应使用日志框架(如Log4j、SLF4J)管理日志输出。webapps目录是否正确部署应用,以及防火墙是否开放8080端口(sudo ufw allow 8080)。