如何用JSP将内容导入Web站点


JSTL转换粘结剂(redux)

清单 1. 经常转换索引页(请注意jsp:include元素)

<%@ page language="java" contentType="text/html" %><%@ taglib prefix="c" uri="http://java.sun.com/jstl/core" %><html><head><title>newInstance.com</title><meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" /><link href="/styles/default.css" rel="stylesheet" type="text/css" /></head><body><jsp:include page="header.jsp" flush="true"><jsp:param name="pageTitle" value="newInstance.com"/><jsp:param name="pageSlogan" value=" " /></jsp:include><%@ include file="/navigation.jsp" %><c:import url="bookshelf.jsp" /><c:import url="/mt-blogs/index.jsp" /><%@ include file="/footer.jsp" %></body></html>

 

转换参数标记

由于已经转换了使用 c:import 而不是 jsp:include 标记的几乎整个索引文件,因此,我们最后的工作就是转变仍然传递 jsp:include 元素的参数,即采用 c:import 标记来模仿 jsp:include 的特性。如清单2所示,我们需要将 jsp:param 转换为 c:param ;因为 c:param 函数类似于JSP的相应功能,因而我们可以轻松处理。

清单2表明,清单1的索引文件已完全转换为JSTL:

 

清单 2. 完整的JSTL转换

<%@ page language="java" contentType="text/html" %><%@ taglib prefix="c" uri="http://java.sun.com/jstl/core" %><html><head><title>newInstance.com</title><meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" /><link href="/styles/default.css" rel="stylesheet" type="text/css" /></head><body><c:import url="header.jsp"><c:param name="pageTitle" value="newInstance.com"/><c:param name="pageSlogan" value=" " /></c:import><%@ include file="/navigation.jsp" %><c:import url="bookshelf.jsp" /><c:import url="/mt-blogs/index.jsp" /><%@ include file="/footer.jsp" %></body>jsp:include</html> 

 

不过您一定要记着, c:param 和 jsp:param 非常相似。现在,让我们进一步研究 c:import 的更多新功能。

导入外部内容
使用 c:import 的真正优势在于,它可以引入外部Web站点的内容或Web应用程序。在前面学习jsp:includes时,您可能已经注意到,我们使用file(文件)属性来为include指定静态内容。file(文件)属性正如其名称所示:使您可以引入本地文件的内容。 c:import 的相应属性为 url ,它也正如其名称所示:使您能够引入任何URL。 c:import 不仅可以使用本地文件的内容来填充您的站点网页,而且还允许您引入任何URL的内容,使其它站点的内容可以真正灵活地适应您自己站点的外观和风格。

让我们举一个实例。我把马达加斯加岛红木吉他的一些美丽图片放到我的Web站点。当我制作自己的网页并完成一些图像文件和相关链接之后,我可以轻松地引入另一个站点的内容,然后使其适合自己站点的外观和风格。清单3表明,使用 c:import 的 url 属性,可以多么容易地引入我所相中的吉他站点的图像文件:

清单 3. 导入外部内容

<%@ page language="java" contentType="text/html" %><%@ taglib prefix="c" uri="http://java.sun.com/jstl/core" %><html><head><title>newInstance.com</title><meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" /><link href="/styles/default.css" rel="stylesheet" type="text/css" /></head><body><c:import url="header.jsp"><c:param name="pageTitle" value="newInstance.com :: True North Guitars"/><c:param name="pageSlogan" value="...building it from scratch" /></c:import><%@ include file="/navigation.jsp" %><c:import url="bookshelf.jsp" /><c:import url="http://www.truenorthguitars.com/Clients/Richman/index.htm" /><%@ include file="/footer.jsp" %></body></html>

 

这些代码看上去没有问题—— 但是,如果您试着在自己站点运行,您很快就会发现问题。所有图像都不显示,并且相关链接全部出现故障。当然,如果仔细想想,原因很很简单。因为外部资源(本例中是图像文件)被解释(interpreted),而您将解释结果直接导入您的输出流。外部图像文件链接如 /images/guitar-01-24.jpg 将显示不存在。解决该问题的唯一方法是将原图像复制到您的站点,与简单的导入相比,这是一项完全不同(并且消耗更多时间)的技术。

因此,最好知道要导入的外部内容是否是纯文本。例如,要考虑连接到系统管理员的站点及其本身的头文件、脚注文件、外观和风格。该站点的网页详细说明如何设置 README 文件,以便用户可以查看如何使用该站点。您可以参考以下现有FTP站点的说明:

<c:import url="ftp://ftp.oreilly.com/pub/README.ftp" />

 

请注意,这非常简单,就如同引入HTTP材料一样导入FTP服务器内容。您可以使用同样的HTTPS命令以及您的站点和目标站点可以识读的任何其它协议。

为什么要采用JSTL?
在核心JSP标记上使用JSTL有以下几大优势。首先,JSTL现在采用独立于JSP标记的规范来定义。因此,即使JSP规范发生改动,也可以保证 JSTL标记的一致性。容易受到JSP容器变更影响的许多应用程序都将受益于JSTL规范.其次,JSTL具有比核心JSP标记更强大的功能,正如您在最佳实践系列中所视, c:import不仅 可以导入其它站点的URL,而且,它还可以导入 jsp:include 标记不可用的更为复杂的内容。最后,JSTL使用自己的表达式语言(通常简称为EL)。JSTL EL可以相当灵活地写入JSP代码,是对核心JSP语言的有力补充。

(责任编辑:城尘)

 

本文作者:
« 
» 
快速导航

Copyright © 2016 phpStudy | 豫ICP备2021030365号-3