在这个颜值当道,屌丝闪边的时代,拼不过颜值拼内涵,只有知识丰富才能提升一个人的内在气质和修养,所谓人丑就要多学习,今天给大家分享JSP中include指令和include行为的区别,希望可以对大家能有小小的帮助。
我们都知道在jsp中include有两种形式,分别是
%@ include file=” ”%
page=” ” flush=”true”/
前者是指令元素、后者是行为元素。具体它们将在何处用?如何用及它们有什么区别?这应该是很多人看到它都会想到的问题。下面一起来看看吧。
通常当应用程序中所有的页面的某些部分(例如标题、页脚和导航栏)都相同的时候,我们就可以考虑用include。具体在哪些时候用 %@ include file=” ”%,哪些时候用 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文件叫。被引入的页面叫这个文件里存放的是一个有关时间的代码,当前的上下文根设为
//======的源文件
%@ page language=”java” contentType="text/html;charset=gb2312"%
%
date=new ();
String date_cn ="";
String dateStr = "";
switch(())
{
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_cn + ")";
%
("%%");
//======以下是的源文件
%@ page language=”java” contentType=”text/html;charset=gb2312”%
html
head
titleinclude的两种用法/title
page=”date.jsp” flush=”true”/
%--@ include file=”date.jsp” %--
//我们在这里用include的两种不同形式来引入这个文件.
head
body
tabletrtd
有关jsp中include的两种用法.敬请关注。
/td/tr/table
/body
/html
在test.jsp 文件中,我们只输出了一行文本“ 有关jsp中include的两种用法.敬请关注。”,现在让我们先用这种形式引入这个文件。你想会出现什么问题了吗?此时出现了错误提示:
HTTP Status 500 ?
: /(,) Page directive:
can't have multiple occurrences of contentType
以还有一堆错误,但我们只要看这里就知道问题的所在了。状态码为http 500服务器内部错误。再看下面的提示。在页面中不能指定多个.
原因就在这里了。是因为在翻译阶段,文件的代码被原封不动地加入到了页面从而合成一个文件。合成后的文件中就会相同的:
%@ page language=”java” contentType=”text/html;charset=gb2312”%
这句代码。解决的办法是把文件中的这句删掉。刷新后再请求页面
请求在页面显示如下
12月10日 13:12:40
有关jsp中include的两种用法.敬请关注。
这时我们还不能发现什么。还是去查看tomcat下的临时文件吧。到那里去看看文件的内容是否已被加入到了文件中。
注.此处的tomcat装在E盘根目录下
目录
E:omcatworkStandalonelocalhostest.
在这个目录下会看到
和两个文件。
这里的java文件就是jsp容器将jsp转化成了servlet而得到的这个文件。
相对应的这个文件就是编译这个文件产生的类文件了。打开所产生的文件。此时我们会发现,在 文件被转化成servlet文件时,在输出的 haed 之间加入了一些不是页面里面的代码,新加入的内容就是 里面的代码: 新加入了哪些内容或是否真的加入了新的内容请自己测试去看一下就会一目了然了.在这里不再详述.
以上就是我们用 %@ include file=””%这种形式得到的结果.
下面我们换用 page=”dae.jsp” flush=”true”/也就是将
%@ include file=””%换成 page=”dae.jsp” flush=”true”/,然后请求test.jsp.
? ê 12??10?? 13:30:13
有关jsp中include的两种用法.敬请关注。
此时会在页面上看见.我们所引入输出的日期中中文出现了乱码什么原因?是因为行为元素是在请求处理阶段执行的(此处要对请求处理阶段进行说明一下容器除了上面提到的负责将页面转化成外,还负责调用页面实现类以处理每个请求并产生应答这个阶段我们就称为请求处理阶段请求处理阶段仅执行类文件)。
所以在我们作include行为元素引入页面时,实际只是引用了这个文件被转化并被编译后产生的servlet类文件.既如此, 就是作为一个单独的文件在执行后才被文件运行时调用由于文件中没有指定字符编码所以出现了乱码解决办法是在文件中重新把刚才去掉的
这行语句加入后刷新重新运行.此时页面显示正确,并跟用include指令正常运行时一样.再查看tomcat下的临时文件会发现.此时多出了一个 文件和一个文件这两个文件得来的方式跟和 文件得来的方式一样再查看一下此时文件的代码会发现此时只新增加了一句代码:
(request, response, "date.jsp", out, true);
它并没有把文件的代码加入到.
只是在运行时引入了页面执行后所产生的应答这意味着我们可以指定任何能够产生应答的资源,(例如一个或一个页面),只要这些资源所产生的类型和页面产生的内容类型相同容器将通过一个内部的函数调用来执行指定的资源因此,这些被引入的资源可以帮助处理原来的请求,所以这些资源可以访问请求作用域内的所有对象以及所有原来的请求参数.
由于在主页面被请求时,这些页面还没有被引入到主页面中,所以你可以对page属性使用一个请求时属性值,以便根据运行时的情况来决定要引入哪一个页面.还可以添加一些将被引入的页面读取的请求参数.
page=”%=pageSelectedAtRuntime%” flush=”true”
name=”fitstParamer” value=”firstValue”
name=”lastParamer” value=”lastValue”
/
如果修改了被引入的jsp页面,那么可以立刻使用该页面的最新版本,这是因为对待被引入的页面的方式与对待由浏览器直接调用的jsp页面的方式完全相同.即容器检测页面的变化,并自动进入翻译阶段,以得到页面的最新版本.
(注意,include行为元素同jsp其它元素一样,没有行为体时要以”/”结束.就像下面这样.
page=”” flush=”true” /
以下是对include 两种用法的区别
主要有两个方面的不同;
1.执行时间上:
%@ include file=”relativeURI”% 是在翻译阶段执行
page=”relativeURI” flush=”true” / 在请求处理阶段执行.
2.引入内容的不同:
%@ include file=”relativeURI”%
引入静态文本(html,jsp),在JSP页面被转化成servlet之前和它融和到一起.
page=”relativeURI” flush=”true” /引入执行页面或servlet所生成的应答文本.
另外在两种用法中file和page属性都被解释为一个相对的URI.如果它以斜杠开头,那么它就是一个环境相关的路径.将根据赋给应用程序的URI的前缀进行解释,如果它不是以斜杠开头,那么就是页面相关的路径,就根据引入这个文件的页面所在的路径进行解释.更多有关URL是如何解释的请参考相关资料或书籍。