1、JSP容器的过期检查机制:
JSP编译成Java源文件:
java weblogic.jspc -keepgenerated -d .\WEB-INF\classes index.jsp;
将在\WEB-INF\classes\jsp_servlet生成__index.java文件;
// StaleIndicator interface
public boolean _isStale() {
weblogic.servlet.jsp.StaleChecker sci =(weblogic.servlet.jsp.StaleChecker)(getServletConfig().getServletContext());
java.io.File f = null;
long lastModWhenBuilt = 0L;
if (sci.isResourceStale("/index.jsp", 1174625990234L, "8.1.6.0", "Asia/Shanghai")) return true;
return false;
}
public static boolean _staticIsStale(weblogic.servlet.jsp.StaleChecker sci) {
java.io.File f = null;
long lastModWhenBuilt = 0L;
if (sci.isResourceStale("/index.jsp", 1174625990234L, "8.1.6.0", "Asia/Shanghai")) return true;
return false;
}
源文件中包含两个方法,_staticIsStale(),其中包含文件名称、编译时间、版本、时区
1、 要检查的资源,比如,/foo.jsp。
2、 JSP页面的时间戳(长整型)。
3、 WebLogic Release Build版。
4、 当前机器的默认时区。
_isStale()方法被回调,决定是否需要重新编译。
weblogic.servlet.jsp.StaleChecker.isResourceStale()
2、静态包含文件变化,也会导致JSP重新编译:
<%@ include file="header.inc"%>
_staticIsStale()方法中也会包含header.inc文件时间的记录。
3、导致重新编译的原因:
JSP编译后,JSP源文件被上传或复制到另一目录下,源文件时间戳改变,导致重编译。
修改weblogic.xml的packagePrefix参数将导致重新编译。
修改weblogic.xml的workingDir参数也会导致重新编译。
将预构建的WAR部属到一个更新版本的WebLogic服务器会导致重新编译所有JSP。
4、如何控制过期检查:
weblogic.xml JSP文件检查周期设置(秒,-1为永不检查)
<weblogic-web-app>
<jsp-descriptor>
<jsp-param>
<param-name>
pageCheckSeconds </param-name>
<param-value>
-1 </param-value>
</jsp-param>
</jsp-descriptor>
</weblogic-web-app>
weblogic.xml /WEB-INF/class检查周期设置(秒,-1为永不检查)
<weblogic-web-app>
<container-descriptor>
<servlet-reload-check-secs>
-1 </servlet-reload-check-secs>
</container-descriptor>
</weblogic-web-app>
JSP类加载器
每个JSP都是在自己的类加载器(通常称为一次性类加载器)中加载的。该类加载器是Web应用程序类加载器的子加载器,负责加载有关的JSP类及其内部类(如果有的话)。
更加简单的控制个别JSP文件改动导致所有JSP重新编译。