调试前需确保系统已安装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)。