原文:https://www.ibm.com/developerworks/cn/java/j-jsp04293/
JSP
include 伪指令的不足之处有一个是:它会导致 Web
浏览器高速缓存所有页面。在处理诸如页脚、版权声明或一组静态链接之类的静态组件时,这是有意义的。这些文件不会改变,因此没有理由让 JSP
解释器不断地重新轮询其中的数据。凡是可能的地方,都应该实现高速缓存,因为它改善了应用程序的性能。
但是,有时侯,进行高速缓存会得不偿失。如果提入的内容来自使用动态数据(如 Weblog 或数据库驱动的 JSP
文件)的程序,甚至如果所包含的内容是经常变化的 HTML(如时间戳记),那么每当装入 Web
页面时,都需要显示这些文件或程序的最新版本。遗憾的是,JSP
include 伪指令并不具备这一功能。在测试和开发周期(请参阅侧栏“
JSP 测试和开发”)中,在浏览器中禁用高速缓存通常能够解决这一问题。但是,对于实际使用的应用程序而言,性能是任何设计决策过程中的一项重要因素,禁用高速缓存并不是一种可行的长远之计。更好的解决方案是使用
jsp:include 标记。
如果您有点爱刨根问底,那么可能十分想知道
jsp:include 标记的行为为什么与
include 伪指令不同。道理其实十分简单:
jsp:include 包含的是所包含 URI 的
响应,而不是 URI 本身。这意味着:对所指出的 URI 进行
解释,因而包含的是
生成的响应。如果页面是 HTML,那么将得到一点也没有变化的 HTML。但是,如果是 Perl 脚本、Java
servlet 或者 CGI 程序,那么得到的将是从该程序解释而得的结果。虽然页面通常就是
HTML,但实际程序恰好是达到目的的手段。而且,由于每次请求页面的时候都会进行解释,因此从来不会象使用
include 伪指令时那样高速缓存结果。虽然这只是很小的变动,但它却导致了您所见到的行为中的全部差异。
|