针对于JSP页面编译问题.
好好总结一下今天下午和同事遇见的一个平时不是那么在意的问题,搞了个半天.
针对于JSP页面编译问题.
我们来看看JSP的编译问题:因为JSP在执行第一次后,会被编译成Servlet的类文件,即.class,当再重复调用执行时,就直接执行第
一次所产生的Servlet,而不再重新把JSP编译成Servelt。
因此,除了第一次的编译会花较久的时间之外,之后JSP和Servlet的执行速度就几乎相同了。 当JSP网页在执行时,JSP Container 会做检查工作,如果发现JSP网页有更新修改时,JSP Container 才会再次编译JSP成 Servlet; 如果JSP没有更新时,就直接执行前面所产生的Servlet.
然而, 我们JSP又会时常的调用Java代码, 而我们大家的Java代码会时刻注意,经常的会时刻的编译,更新. 而你页面
Java代码里面:
public class Constants{
// 之前的代码
public static final String FUID = 1;
// 改动之后的代码, 将String 修改为 int
public static final int FUID = 1;
}
而JSP一直没有变,也不需要改变.
<input type="hidden" value="<%=Constants.FUID%>" />
所以,当访问改JSP页面是, 它的class还是之前的,因为你没有改动过文件,而后台的Java已经改变,所以会报错,说找不到FUID(String)的. 因为你已经是int类型的FUID了.
解决方法就是: 每次重启时, 都需要删掉 ~/tomcat/work/Catalina/localhost/webProject/* 的所有文件,让它重新编译.
大概就是这么个意思,不知道大家看明白了.如果一直是这么做的, 那就没问题了.