`

JSP中动态INCLUDE与静态INCLUDE的区别

阅读更多
我们都知道在jsp中include有两种形式,分别是

    <%@ include file=" "%>

    <jsp:include page=" " flush="true"/>

    前者是指令元素、后者是行为元素.

    通常当应用程序中所有的页面的某些部分(例如标题、页脚和导航栏)都相同的时候,我们就可以考虑用include.具体在哪些时候用<%@ include file=" "%>,哪些时候用<jsp:include page=" " flush="true"/>.这种形式.首先要明白的是它们之间的区别.

    <%@ include file=" "%>,jsp的include指令元素读入指定页面的内容.并把这些内容和原来的页面融合到一起.(这个过程是在翻译阶段:也就是jsp被转化成servlet的阶段进行的).

    这里对翻译阶段进行一下说明:我们知道,jsp页面不能原封不动地被传送给浏览器,所有的jsp元素都必须首先由服务器进行处理.这是通过将jsp页面转达化成servlet,然后执行这个servlet来完成的.服务器需要一个jsp容器来处理jsp页面.jsp容器通常以servlet的形式来实现,这个servlet经过配置,可以处理对jsp页面的所有请求.

    Jsp容器负责将jsp页面转化成servlet(称为jsp页面实现类?JSP Page implementation class),并编译这个servlet.这两步就构成了翻译阶段.

    由此我们就会知道:jsp页面是把include指令元素所指定的页面的实际内容(也就是代码段)加入到引入它的jsp页面中,合成一个文件后被jsp容器将它转化成servlet.可以看到这时会产生一个临时class文件和一个java文件.下面举个例子.

    服务器用tomcat,引入页面的jsp文件叫test.jsp.被引入的页面叫date.jsp.这个jsp文件里存放的是一个有关时间的jsp代码,当前的上下文根设为test

    //======date.jsp的源文件=====//

    <%@ page language="java" contentType="text/html;charset=gb2312"%>

    <%

    java.util.Date date=new java.util.Date();

    String date_cn ="";

    String dateStr = "";

    switch(date.getDay())

    {

    case 0:date_cn ="日"; break;

    case 1:date_cn ="一"; break;

    case 2:date_cn ="二"; break;

    case 3:date_cn ="三"; break;

    case 4:date_cn ="四"; break;

    case 5:date_cn ="五"; break;

    case 6:date_cn ="六"; break;

    }

    dateStr = (1900+date.getYear()) + "年" + (date.getMonth()+1) + "月" + date.getDate() + "日(星期" + date_cn + ")";

    %>

    document.write("<%=dateStr%>");

    //======以下是test.jsp的源文件=============//

    <%@ page language="java" contentType="text/html;charset=gb2312"%>

    <html>

    <head>

    <title>include的两种用法</title>

    <jsp:include page="date.jsp" flush="true"/>

    <%--@ include file="date.jsp" %-->

    //我们在这里用include的两种不同形式来引入date.jsp这个文件.

    <head>

    <body>

    <table><tr><td>

    有关jsp中include的两种用法.敬请关注.

    </td></tr></table>

    </body>

    </html>

    在test.jsp 文件中,我们只输出了一行文本" 有关jsp中include的两种用法.敬请关注.",现在让我们先用<%@ include file="date.jsp" %>这种形式引入date.jsp这个文件.你想会出现什么问题了吗?此时出现了错误提示:

    HTTP Status 500 ?

    org.apache.jasper.JasperException: /date.jsp(0,0) Page directive: can't have multiple occurrences of contentType

    以下还有一堆错误,但我们只要看这里就知道问题的所在了.状态码为http 500服务器内部错误.再看下面的提示.在date.jsp页面中不能指定多个contentType.

    原因就在这里了.是因为在翻译阶段,date.jsp文件的代码被原封不动地加入到了test.jsp页面从而合成一个文件.合成后的文件中就会相同的:

    <%@ page language="java" contentType="text/html;charset=gb2312"%>

    这句代码.解决的办法是把date.jsp文件中的这句删掉.刷新后再请求test.jsp页面

    请求test.jsp在页面显示如下

    2003年12月10日 13:12:40

    有关jsp中include的两种用法.敬请关注.

    这时我们还不能发现什么.还是去查看tomcat下的临时文件吧.到那里去看看date.jsp文件的内容是否已被加入到了test.jsp文件中.

    <注.此处的tomcat装在E盘根目录下>

    目录

    E:\tomcat\work\Standalone\localhost\test.

    在这个目录下会看到

    test_jsp.java和test_jsp.class两个文件.

    这里的java文件就是jsp容器将jsp转化成了servlet而得到的test_jsp.java这个文件.

    相对应的test_jsp.class这个文件就是编译test_jsp.java这个servlet文件产生的类文件了.打开所产生的servlet文件(test_jsp.java).此时我们会发现,在test.jsp 文件被转化成servlet文件时,在输出的<haed>之间加入了一些不是test.jsp页面里面的代码,新加入的内容就是 date.jsp里面的代码: 新加入了哪些内容或是否真的加入了新的内容请自己测试去看一下就会一目了然了.在这里不再详述.

    以上就是我们用<%@ include file="date.jsp"%>这种形式得到的结果.

    下面我们换用<jsp:include page="dae.jsp" flush="true"/>也就是将

    <%@ include file="date.jsp"%>换成<jsp:include page="dae.jsp" flush="true"/>,然后请求test.jsp.

    2003? ê 12??10?? 13:30:13

    有关jsp中include的两种用法.敬请关注.

    此时会在页面上看见.我们所引入date.jsp输出的日期中中文出现了乱码.什么原因?是因为include行为元素是在请求处理阶段执行的(此处要对请求处理阶段进行说明一下.Jsp容器除了上面提到的负责将jsp页面转化成servlet外,还负责调用jsp页面实现类以处理每个请求并产生应答.这个阶段我们就称为请求处理阶段.请求处理阶段仅执行类文件).

    所以在我们作include行为元素引入页面时,实际只是引用了date.jsp这个文件被转化并被编译后产生的servlet类文件.既如此, date.jsp就是作为一个单独的文件在执行后才被test.jsp文件运行时调用.由于date.jsp文件中没有指定字符编码.所以出现了乱码.解决办法是在date.jsp文件中重新把刚才去掉的

    <%@ page language="java" contentType="text/html;charset=gb2312"%>

    这行语句加入后刷新重新运行.此时页面显示正确,并跟用include指令正常运行时一样.再查看tomcat下的临时文件会发现.此时多出了一个 date_jsp.java文件和一个date_jsp.class文件.这两个文件得来的方式跟test_jsp.java和 test_jsp.class文件得来的方式一样.再查看一下此时test_jsp.java文件的代码会发现.此时只新增加了一句代码:

    JspRuntimeLibrary.include(request, response, "date.jsp", out, true);

    它并没有把date.jsp文件的代码加入到test.jsp.

    只是在运行时引入了date.jsp页面执行后所产生的应答.这意味着我们可以指定任何能够产生应答的Web资源,(例如一个servlet或一个jsp页面),只要这些资源所产生的类型和jsp页面产生的内容类型相同.JSP容器将通过一个内部的函数调用来执行指定的资源.因此,这些被引入的资源可以帮助处理原来的请求,所以这些资源可以访问请求作用域内的所有对象.以及所有原来的请求参数.

    由于在主页面被请求时,这些页面还没有被引入到主页面中,所以你可以对page属性使用一个请求时属性值,以便根据运行时的情况来决定要引入哪一个页面.还可以添加一些将被引入的页面读取的请求参数.

    <jsp:include page="<%=pageSelectedAtRuntime%>" flush="true" >

    <jsp:param name="fitstParamer" value="firstValue">

    <jsp:param name="lastParamer" value="lastValue">

    </jsp:include>

    如果修改了被引入的jsp页面,那么可以立刻使用该页面的最新版本,这是因为对待被引入的页面的方式与对待由浏览器直接调用的jsp页面的方式完全相同.即容器检测页面的变化,并自动进入翻译阶段,以得到页面的最新版本.

    (注意,include行为元素同jsp其它元素一样,没有行为体时要以"/"结束.就像下面这样.

    <jsp:include page="<%=pageSelectedAtRuntime%>" flush="true" />)

    以下是对include 两种用法的区别

    主要有两个方面的不同;

    一:执行时间上:

    <%@ include file="relativeURI"%> 是在翻译阶段执行

    <jsp:include page="relativeURI" flush="true" /> 在请求处理阶段执行.

    二:引入内容的不同:

    <%@ include file="relativeURI"%>

    引入静态文本(html,jsp),在JSP页面被转化成servlet之前和它融和到一起.

    <jsp:include page="relativeURI" flush="true" />引入执行页面或servlet所生成的应答文本.

    另外在两种用法中file和page属性都被解释为一个相对的URI.如果它以斜杠开头,那么它就是一个环境相关的路径.将根据赋给应用程序的URI的前缀进行解释,如果它不是以斜杠开头,那么就是页面相关的路径,就根据引入这个文件的页面所在的路径进行解释.更多有关URL是如何解释的请参考相关资料或书籍.
分享到:
评论

相关推荐

    JSP中动态include与静态include的区别介绍

    动态INCLUDE 用法:&lt;jsp page=”included.jsp” flush=”true”&gt; 说明:它总是会检查所含文件中的变化,适合用于包含动态页面,并且可以带参数,先编译之后再进行处理。 原因:1、静态include的结果是把其他jsp引入...

    JSP下动态INCLUDE与静态INCLUDE的区别分析

     用jsp:include动作实现 &lt;jsp include page=”included.jsp” flush&gt;它总是会检查所含文件中的变化,适合用于包含动态页面,并且可以带参数。 静态INCLUDE   用include伪码实现,定不会检查所含文件的变化,...

    jsp中include指令静态导入和动态导入的区别详解.docx

    JSP 中 Include 指令静态导入和动态导入的区别详解 JSP 中的 Include 指令可以实现静态导入和动态导入两种方式。静态导入和动态导入是 JSP 中 Include 指令的两种不同的实现方式,它们之间有着明显的区别。 静态...

    JSP中include指令静态导入和动态导入的区别.pdf

    与静态导入不同,动态导入在运行时完成,它不会将被导入页面的编译指令合并到主页面中,而是仅在请求处理阶段将被导入页面的`&lt;jsp:body&gt;`部分插入到当前页面。动态导入更灵活,因为它是运行时的行为,所以它可以响应...

    jsp中include指令静态导入和动态导入的区别详解

    JSP中的include指令有两种方式:静态导入和动态导入。了解它们之间的区别,对于开发高效且易于维护的Web应用至关重要。 首先,我们要了解什么是静态导入。在JSP中,静态导入是通过指令%@include file=...

    jsp:include与include实探

    在Java Web开发中,`jsp:include`和`&lt;jsp:include&gt;`标签是两种常见的页面包含机制,它们用于将一个或多个动态或者静态资源合并到一个JSP页面中。这两种方式虽然看似相似,但有着本质的区别,理解它们的用法和区别...

    JSP:include和include指令区别

    1. 动态与静态:`&lt;jsp:include&gt;` 动态包含,`&lt;%@ include %&gt;` 静态包含。 2. 执行时机:`&lt;jsp:include&gt;` 在请求时,`&lt;%@ include %&gt;` 在编译时。 3. 内容变化:`&lt;jsp:include&gt;` 适合动态内容,`&lt;%@ include %&gt;` 适合...

    jsp的Include方式

    静态Include在编译时就会被处理,被包含的页面会被转换成Servlet的源代码并插入到包含它的JSP页面中。这种方式适用于包含静态内容,如头部、底部导航等不经常变动的部分。 2. **动态Include(&lt;jsp:forward&gt;)** ...

    jsp的include的两种用法

    这意味着 `&lt;jsp:include page=” ” flush=”true”/&gt;` 可以在每次请求时动态地包含其他 JSP 文件,而不是在翻译阶段包含静态内容。 例如,在 test.jsp 文件中,我们可以使用 `&lt;jsp:include page=”date.jsp” ...

    动态Jsp页面转换成静态Html页面

    在Java EE开发中,动态网页技术如JSP(JavaServer Pages)被广泛用于构建交互式Web应用程序。然而,为了提高网站性能,降低服务器负载,并优化搜索引擎优化(SEO),经常需要将动态JSP页面转换为静态HTML页面。这个...

    JSP动态生成HTML静态页面源码

    学习这个源码,你可以深入理解JSP与静态页面之间的转换机制,这对于提升Web应用性能、优化用户体验和进行大规模网站架构设计都有很大的帮助。同时,这也是一种常见的Web缓存策略,对于了解Web开发中的性能优化技术也...

    jsp中两种包含关系(include动作和include指令)的区别

    `&lt;%@ include file="..."%&gt;` 是一个JSP指令,它在编译时(页面转换为Servlet时)静态地将一个文件的内容插入到JSP页面中。这意味着被包含的页面只会被包含一次,除非JSP文件重新编译。例如: ```jsp &lt;%@ include ...

    JSP常见的三个编译指令page、include、taglib

    jsp中include指令静态导入和动态导入的区别详解JSP编译指令page、include详解JSP中动态include与静态include的区别介绍JSP指令元素(page指令/include指令/taglib指令)复习整理基于jsp:included的使用与jsp:param乱码...

    JSP基础语法-include指令

    通过理解JSP中的`include`指令,尤其是静态包含和动态包含的区别,开发者可以更灵活地管理项目中的代码结构,提高代码的模块化程度,从而提升项目的整体性能和开发效率。在后续的学习中,可以进一步探索JSP的其他...

    JSP中include指令和include行为的区别

    通常当应用程序中所有的页面的某些部分(例如标题、页脚和导航栏)都相同的时候,我们就可以考虑用include。具体在哪些时候用&lt; %@ include file=” ”%&gt;,哪些时候用&lt; jsp:include page=” ” flush=...

    jsp简单静态网页

    【标题】"jsp简单静态网页" 涉及的知识点主要集中在JavaServer Pages(JSP)技术上,这是一种用于创建动态网页的服务器端脚本语言,它与HTML、CSS和JavaScript一起工作,允许开发者在HTML页面中嵌入Java代码,以实现...

    jsp生成静态页面的方法

    本文将详细介绍如何利用JSP与Servlet技术实现动态页面到静态页面的转换。 #### 技术背景 - **JSP**:一种用于生成动态Web页面的技术,允许将HTML、CSS、JavaScript等静态内容与Java代码混合编写。 - **Servlet**:...

Global site tag (gtag.js) - Google Analytics