科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道在Web服务客户端应用JSP

在Web服务客户端应用JSP

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

JavaServer Pages,也叫做JSP,是用来让Web开发人员在不需要Java代码的情况下实现动态HTML页面创建的Java servlet的扩展技术

作者: William Brogden 来源:IT专家网 2008年4月17日

关键字: 客户端 服务 web java

  • 评论
  • 分享微博
  • 分享邮件
当服务器获得对JSP页面的请求后,就启动一系列的事件生成Java servlet来响应。通过这种过程,JSP代码转换成为servlet,这也是JSP被开发人员广泛应用的关键。

  页面的JSP代码包含了普通的HTML标记和特殊的“tag”。普通的HTML可以被看作被tag的动作所填充的模版。专门的JSP编译器把JSP代码转换成有效的Java servlet代码,再用普通的Java编译器转换成servlet类。服务器则把JSP页面的名称映射到生成的servlet上。因此,对于Web设计人员来说,就好象JSP代码被执行一样,不过背后却做了很多事情。

  简单的"scriptlet" tag允许你在HTML标签中间加入Java语句。你还可以声明完整的Java方法,使其成为servlet代码的一部分。用这些方法,你可以访问任何可扩展的Java库,因此你可以构建十分复杂的JSP,不过这不见得好罢了。

  JSP tag是对Java代码的额外扩展,这些代码一般是手工创建起来很麻烦的。这样做不好的地方在于JSP比普通Java代码更难调试。Tag扩展了基本的JSP语法,它可以被组织在称为“taglibs”的tag库中。在使用时,必须被显式加入页面中。

  JSP, "Model 1" and "Model 2"

  JSP技术刚被使用时,程序员很乐意把所有的决策制定等类似功能加入到JSP代码中。这样做很容易,而且你的代码都在一个文件中。但是,随着应用不断变大,这种方法变得很难调式和维护。实际上,它变得非常可怕。

  最近,这种在JSP中集中处理的方式被成为"Model 1"。它只用在那些基于很少的用户请求就能做决策的最简单的应用中。而更好的架构被称为"Model 2",它是用servlet来检查所有用户的请求,做运算并决定用哪个JSP来显示结果。这种设计模式被称为“Model-View-Controller (MVC)”,即用JSP根据请求来提供HTML视图,而用servlet来做控制器。注意:MVC中的M是指底层的数据,在Model1和Model2中都是如此。

  于是我们很快就能发现,可以用JSP页面来直接访问Web服务,解析结果并控制表示。但是,假如页面获得很多用户交互,那么就会由于重复获得同样内容而产生大量的低效复制工作。对于那些最简单的少交互页面。在从Web服务获得数据后绘制JSP时,应该间接地工作。

  JSP标准Tag库

  很多业界专家在Java Community Process (JSR 52)之下标准化了一套基本的tag,称为JSP Standard Tag Library (JSTL)。可是并非像名字那样简单。实际上,由于Java Servlet和JSP API标准的不断发展,现在存在多种版本的JSTL。

  最早的JSTL1.0版对应Servlet2.3版及JSP1.2版。Tomcat 4是实现了这种JSP API的参考servlet引擎。

  JSTL1.1版对应Servlet2.4版及JSP2.0版。Tomcat 5是实现了这种JSP API的参考servlet引擎。

  最新的Java Enterprise Edition 5拥有JSTL1.2版。据我所知,这个版本中的更新是实现了JavaServer Faces应用框架于JSP的集成。Java EE 5已在两周前进入了最终发布状态。

  用标准Tag库访问Web服务

  为了用JSP进行展示,我从Apache Software Foundation网站下载了JSTL1.1包。这个包包含了很多很多JSTL之外的东西,因为该开源组织在为JSP创建定制tag库方面一直都很积极。我用Tomcat5.5.9做servlet容器。

我们使用的Web服务是关联到新闻Web服务的TechTarget的RSS种子。原先的RSS代表了Rich Site Summary,但今天,RSS则表示Really Simple Syndication。不管怎样,RSS使用到很简单的XML文件格式,很适合用JSTL来解析。我的JSP页面用两个tag开始,它们指定了被使用的taglib和在tag中出现的命名空间的前缀。此外,还有一些标准的HTML标签。

  <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
  <%@ taglib prefix="x" uri="http://java.sun.com/jsp/jstl/xml" %>
  <html><head><title>JSTL: XML Demo</title>
  </head><body bgcolor="#FFFFFF">
  <h1>Test RSS Feed from Techtarget</h1>

  接着,我们用tag来定义如何获得源文件,并用保存在局部变量“document”中的引用解析成标准Java XML文档对象。

  <c:import var="docString" url="http://rss.techtarget.com/80.xml"/>
  <x:parse var="document" doc="${docString}"/>

  XML解析工作如下:我已经添加了行数以方便解释。第一行用xml taglib的“set”动作把"channel"变量设为XML文档的根元素。第二行把"description"tag的内容加到HTML标签中。第三行是用于格式化未标号清单的HTML标签。

1. <x:set var="channel" select="$document//channel" />
2. <p>< x:out select="$channel//description"/></p>
3. <ul>
4. <x:forEach select="$channel//item" >
5.   <li><a href='<x:out select="link" />' >
6.     <x:out select="title"/></a></li>
7. </x:forEach>
8. < /ul>

  RSS"channel"元素包含代表每个新闻标题的"item"元素。每个"item"元素有一个"title",一个指向源网站的"link",一大端描述以及一些其它元素。Web开发人员可以用很多方法在不同的JSP中使用这些数据。本例中,我只用了一个简单的表示层。

  接着,我们用forEach tag把所有的"item"元素输出到文档中。遵循XPath格式的"select"属性为item元素创建一个nodelist。在第五行,我把"link"元素的内容嵌入到HTML标签中作为超连接。而在第六行,我用"title"元素的内容创建被显示的文本。

  用浏览器打开Tomcat Web服务器中的JSP页面,将看到标题为"Test RSS Feed from Techtarget,"的页面,以及包含RSS描述的段落和一列标题。每个标题都是可以点击的指向对应页面的链接。

    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章