在这篇文章中,我将为大家介绍一种基于JSP且灵活有趣的技术,那就是JSTL.JSTL全称为 JAVA SERVER PAGES STANDARD TAG LIBRARY.虽然JSP已经变的非常流行,但JSTL在基于SQL数据库的简单、快速的前后台开发中还是没有被广泛的应用。一旦你了解了JSTL,你就会了解到它的优点,并发现在你作为程序员的日常工作中,它已经被应用到了很多方面。我这里假设你已经熟悉HTML,能理解基本的SQL语句,和JSP的基础知识。因为下面的内容要涉及到这些知识。
JSTL是一个已经被标准化的标记库集合,她支持迭代、条件、XML文档的解析,国际化,和利用SQL与数据库交互的功能。起初,JSTL规范一直由JCP (JAVA COMMUNITY PROCESS PROGRAM)组织下的JSR #52 发展完善,"JCP肩负着JAVA 技术发展的重任"--官方网站这样评价。JCP作为一个开放性的组织,他同时吸收正式的会员和非正式会员.JCP对于JAVA技术规范的形成与发展发挥了重要的主导作用。 JSTL主要包括四个基本部分的标记库:CORE,XML,国际化,和对SQL的支持。由于这篇文章的主要是以其中的SQL部分的应用来快速了解 JSTL,所以我们这篇文章只介绍了 CORE和SQL标签库的一些基本功能。
这项技术简单而且功能强大,足以和PHP、 COLDFUSION一较高下.他在拓展JAVA的应用领域方面有足够的能力,这些领域不只包括大型的可再升级的WEB应用程序,对于仅拥有简单主页的 WEB程序一样没问题。这允许你在建立站点的时候可以避免那些经常考虑的XML的集成和与数据库的连接。正如我刚才提到的一样,JSTL的关键点就是简单易用。还有,那就是JSTL是基于JSP构建的, 他允许我们使用所有的JAVA技术,这一点我们有必要记住。
开始之前,我们需要弄清楚怎样才能运行JSTL.由于是基于JSP技术的,所以我们运行它就需要一个能够编译JSP的容器,这里我们使用免费的JSP容器:TOMCAT (HTTP://JAKARTA.APACHE.ORG/TOMCAT/INDEX.HTML).至于如何安装这个产品已经超出了本文所讲述的范围。毫无疑问,这个软件产品现在已经很普及了,而且关于如何安装的文档资料也是很多。这里假设您已经安装并成功配置了这个容器,你只需再安装JSTL运行所需文件即可,它可以从这里下载HTTP://JAKARTA.APACHE.ORG/TAGLIBS/DOC/STANDARD-DOC/INTRO.HTML 你不需要真正的安装它,只需要将其中的.JAR文件包含到你的应用程序的WEB-INF/LIB目录下即可,稍后我会具体说到该怎么做.
因为我们要在一个支持标准SQL的数据库上运行程序,你需要在你的电脑上安装有一个数据库。数据库的类型有许多种,这里我选择了MYSQL。我之所以选择他的原因在于首先,我们需要展示JSTL对于构造简单快速的应用程序领域所起的作用,同时能和一直在这个领域处于主导地位的PHP+MYSQL有所比较;第二点那就是MYSQL是可以免费下载并包含有一个针对JAVA的JDBC驱动.总之,为了使用下面的例子,你需要下载一个MYSQL服务器 (HTTP://WWW.MYSQL.COM/PRODUCTS/MYSQL/INDEX.HTML; MYSQL CONNECTOR/J JDBC驱动程序HTTP://WWW.MYSQL.COM/PRODUCTS/CONNECTOR-J/INDEX.HTML;还有就是 MYSQL CONTROL CENTER HTTP://WWW.MYSQL.COM/PRODUCTS/CONNECTOR-J/INDEX.HTML), 这个产品可以让你非常容易的操作管理MYSQL数据库文件。全部下载完成后,你需要安装MYSQL和MYSQL CONTROL CENTER。另外还有就是MYSQL的JDBC驱动需要放到你的WEB应用程序中的/WEB-INF/LIB目录中。
在创建程序代码之前,你需要创建并填写数据库表。关于这方面的主题文章也相当广泛,具体如何操作超出了本文的范围。这里我推荐给你我们上面提及的一个可视化的管理工具 MYSQL CONTROL CENTER.你可以用他来创建一个用来运行程序的测试用户,数据库以及创建一个测试表,并填写若干记录。关于登陆名及密码 数据库名称这些配置环境参数,你应该记住他们,稍后需要应用到我们的代码中。
现在,你就可以准备创建自己的第一个JSTL应用程序了它需要我们做下面一些事情:
整个实例程序代码包括两个文件HELLO.JSP和 CONTINUE.JSP
HELLO.JSP文件允许你输入数据库名称、登陆名称、登陆密码、数据库表名。CONTINUE.JSP:接受HELLO.JSP中的数据信息并且连接数据库,并对数据库中的表执行一个Select请求.
下面是这个系统所有的代码文件,我将逐一进行解释。这些代码相当简单,对于代码的结构,我相信你即使没有我的解释你也能理解的.
1: <!-- HELLO.JSP -->
2: <HTML>
3: <HEAD>
4: <TITLE>HELLO</TITLE>
5: </HEAD>
6: <BODY BGCOLOR="#FFFFFF">
7: <H1>PLEASE, ENTER ALL NECESSARY INFORMATION AND CLICK OK.</H1>
8: <FORM METHOD="POST" ACTION="CONTINUE.JSP">
9: <BR>YOUR LOGIN TO DATABASE:
<INPUT TYPE="TEXT" NAME="LOGIN" SIZE="15">
10: <BR>YOUR PASSWORD TO DATABASE:
<INPUT TYPE="PASSWORD" NAME="PASSWORD" SIZE="15">
11: <BR>YOUR DATABASE NAME:
<INPUT TYPE="TEXT" NAME="DATABASE" SIZE="15">
12: <BR>YOUR DATABASE TABLE:
<INPUT TYPE="TEXT" NAME="TABLE" SIZE="15">
13: <BR><BR><INPUT TYPE="SUBMIT" NAME="SUBMIT" VALUE=" OK ">
14: </FORM>
15: </BODY>
16: </HTML>
(请注意文本左侧的数字只是为你提供一些标记信息,你不需要将他们输入到你的代码文件中。)
上面就是所有HELLO.JSP的源代码,很惊奇吧,他仅仅是纯粹的HTML代码,就这么简单,我想应该没有注释的必要了.我之所以将这些代码片段包含进文章中就是为了展示一下JSTL集成到那些需要快速扩充额外功能的HTML站点中是多么的简单.让我再为你展示一下CONTINUE.JSP的全部代码,看过之后,你就会对 JSTL有些了解了。
1: <!-- CONTINUE.JSP -->
2: <%@ TAGLIB PREFIX="C" URI="HTTP://JAVA.SUN.COM/JSTL/CORE" %>
3: <@ TAGLIB PREFIX="SQL" URI="HTTP://JAVA.SUN.COM/JSTL/SQL" %>
4: <C:SET VAR="H" VALUE="LOCALHOST"/>
5: <C:SET VAR="L" VALUE="${PARAM.LOGIN}"/>
6: <C:SET VAR="P" VALUE="${PARAM.PASSWORD}"/>
7: <C:SET VAR="D" VALUE="${PARAM.DATABASE}"/>
8: <C:SET VAR="T" VALUE="${PARAM.TABLE}"/>
9: <HTML>
10: <HEAD>
11: <TITLE>CONTINUE</TITLE>
12: </HEAD>
13: <BODY BGCOLOR="#FFFFFF">
14: <SQL:SETDATASOURCE DRIVER="COM.MYSQL.JDBC.DRIVER"
URL="JDBC:MYSQL://${L}/${D}USER=${U}&PASSWORD=${P}"/>
15: <SQL:QUERY VAR="RESULT">
16: Select * FROM <C:OUT VALUE="${T}"/>
17: </SQL:QUERY>
18: <C:FOREACH VAR="ROW" ITEMS="${RESULT.ROWSBYINDEX}">
19: <C:OUT VALUE="${ROW[0]}"/> <BR>
20: </C:FOREACH>
21: </BODY>
22: </HTML>
(请注意文本左侧的数字只是为你提供一些标记信息,你不需要将他们输入到你的代码文件中。)
这就是我们所有的代码了,是不是非常不错?现在我门来解释一下上面这些代码的作用。
行1 是 HTML 的注释说明。
行2--3 这些 JSP 标签是为了引用外部的 标签库,更确切的说这里是引用了JSTL库中的 CORE 和SQL标签库部分。我们为他们都设置了前缀名称,以便于我们通过这些前缀名称访问被引入的标签库中的功能方法。
行4---8正如 HELLO.JSP 真正运行的样子,他将请求CONTINUE.JSP,CONTINUE.JSP获得请求后就需要得到并解析来自 HELLO.JSP的若干变量,我们使用了这样的方式${PARAM.YOUR_VAR}。在第4行<C:SET标签,将变量${H}设置为 "LOCALHOST",第五行变量${L}将获取我们在 HELLO.JSP中的LOGIN文本域中输入的信息,第6,7,8行的变量将分别获得来自 HELLO.JSP中用户所输入的密码,数据库名称,数据表名称。
行9--13是一些我经常用来常见HTML网页头的简单的HTML标签,马上,重要的功能马上要到了。
行14,我们试图用我们先前获得的MYSQL驱动程序(COM.MYSQL.JDBC.DRIVER)建立数据库连接,在URL中,我们指明数据库连接所需要的参数,象数据库名称,主机名称,登陆名及登陆密码。依此,我们可以用其它任何的JDBC驱动程序连接其相对的数据库。如果我们需要连接其他的 SQL数据库,只需更改这个 URL就够了。
行15--17 这里我们执行了一个Select 查询,请特别注意第16行,我们使用了另一个JSTL功能函数<C:OUT 用来输出我们所获取的数据表名称,这里我们同样可以使用其他的SQL命令,比如说 Insert,Delete, 等等。要执行这些没有返回值的查询请求,你就需要使用<SQL:Update JSTL功能函数了。他可以直接执行他们就象<SQL:QUERY一样,只是执行它是不需要特别指定结果变量来存储语句执行返回的结果。
行18--20 既然我们执行了上面的Select查询语句,我们就应该把他的返回结果显示出来。<C:FOREACH 就是JSTL 中一个具有迭代功能的函数,执行它时,我们通过$ {RESULT.ROWSBYINDEX}将返回的每一个数据行信息返回给变量${ROW},紧接着在第19行, 我们通过<C:OUT VALUE=" ${ROW[0]}"/>显示返回的每个数据行的第一个数据列中的值。只要你的数据表中包含的字段,你都可以通过改变变量 ${ROW}中的数字大小来对请求表中的任意一个字段中的值对他们进行访问。
行21--22是HTML 页脚
在你亲自创建JSTL应用程序过程中,可能你还没有发现它有多么的强大,但你应该能够意识到JSTL的功能函数的简单和高效性,试想有了JSTL,整合出一个基于SQL的新闻专栏是何等的快速,集成你现有的WEB站点是何等的容易。
很好,我们的代码很容易理解的,即使一个非专业程序员的话,打个比方就算是一个设计师也能够读懂它,理解它,还可能进行部分的修改,起码是页面布局上的修改。
点击下载此文件
posted on 2007-06-18 21:31
Zhangwenlong 阅读(1272)
评论(2) 编辑 收藏