Struts和JSF/Tapestry都属于表现层框架,这两种分属不同性质的框架,后者是一种事件驱动型的组件模型,而Struts只是单纯的MVC模式框架,老外总是急吼吼说事件驱动型就比MVC模式框架好,何以见得,我们下面进行详细分析比较一下到底是怎么回事?
首先事件是指从客户端页面(浏览器)由用户操作触发的事件,Struts使用Action来接受浏览器表单提交的事件,这里使用了Command模式,每个继承Action的子类都必须实现一个方法execute。
在Struts中,实际是一个表单Form对应一个Action类(或DispatchAction),换一句话说:在Struts中实际是一个表单只能对应一个事件,Struts这种事件方式称为application event,application event和Component event相比是一种粗粒度的事件。
Struts重要的表单对象ActionForm是一种对象,它代表了一种应用,这个对象中至少包含几个字段,这些字段是Jsp页面表单中的input字段,因为一个表单对应一个事件,所以,当我们需要将事件粒度细化到表单中这些字段时,也就是说,一个字段对应一个事件时,单纯使用Struts就不太可能,当然通过结合JavaScript也是可以转弯实现的。
而这种情况使用JSF就可以方便实现
<h:inputText id="userId" value="#{login.userId}"><f:valueChangeListener type="logindemo.UserLoginChanged" /></h:inputText>
#{login.userId}表示从名为login的JavaBean的getUserId获得的结果,这个功能使用struts也可以实现,name="login" property="userId"
关键是第二行,这里表示如果userId的值改变并且确定提交后,将触发调用类UserLoginChanged的processValueChanged(...)方法。
JSF可以为组件提供两种事件:Value Changed和 Action. 前者我们已经在上节见识过用处,后者就相当于struts中表单提交Action机制,它的JSF写法如下:
<h:commandButton id="login" commandName="login"><f:actionListener type=”logindemo.LoginActionListener” /></h:commandButton>
一、结构
JSP和ASP在结构上类似,都是以““作为标计符,不同的是在标计符之间的代码ASP为Javas cript或VBs cript脚本,而JSP为JAVA代码。JSP将网页的表现形式和服务器端的代码逻辑分开。作为服务器进程的JSP页面,首先被转换成servlet(一种服务器端运行的java程序)。Servlet支持HTTP协议的请求和响应。当JSP被转换成纯JAVA代码。多个用户同时请求一个jsp页面时,应用实例化线程来响应请求。这些线程由WEB服务器进程来管理,和ASP的线程管理器功能类似。同CGI为每个请求创建一个进程的模式比较,这种方式效率高的多。
二、性能和平台无关性
与C++、VB等语言比较,JAVA被看作是个效率不太高的语言,但它以牺牲效率换来了平台无关性使JAVA可以在大多数操作系统上运行而不需要重新编译--许多人愿意为此而付出代价。JAVA的编译代码是一种字节代码,在运行时由操作系统上的一个Java VirtualMachine(JVM)虚拟机解释。字节代码可以在所有平台上迁移,而不需要任何改动。交叉平台编程倾向于采用所有操作系统的“最小公分母“,尤其是使用图形化界面时(servlets不需要任何图形界面)。Servlets比传统的java程序(applets, javaapp)要快,因为它们在服务器端运行,不需要加载沉重的GUI(HTML的GUI是非常少的)。另外,servlets的字节代码只有在客户请求时才执行,所以尽管当首次调用servlets时会有几秒钟的加载时间,但后续的请求相应非常迅速,因为服务器已经缓存了运行的servlets。当前的jsp服务器,都带有java 即时编译器(JIT),因此,JSP的执行比每次都要解释执行的ASP代码要快,尤其是在代码中存在循环操作时,JSP的速度要快1到2个数量级。
三、Session管理
为了跟踪用户的操作状态,ASP应用SESSION对象。JSP使用一个叫HttpSession的对象实现同样的功能。Session的信息保存在服务器端,Session的id保存在客户机的cookie中。如果客户机禁止cookie,Session Id就必须带在url后面。Session一般在服务器上设置了一个30分钟的过期时间,当客户停止活动后自动失效。Session 中保存和检索的信息不能是基本数据类型(primitivedatatypes)如(int, double)等,而必须是java的相应的object(对象)如(Integer,Double)。
HttpSessionsession=request.getSession();//得到一个session对象或创建一个
session.getId()//得到sessionID数
Integerid=(Integer)session.getValue(“id“)//检索出session的值并转化为整型 session.putValue(“ItemValue“,itemName);//ItemValue必须不是must简单类型
四、Application管理
有时服务器需要管理面向整个应用的参数,使得每个客户都能获得同样的参数值。和Session一样,ASP使用Application对象而JSP使用ServletContext对象,操作的方法和Session一样。
getServletContext().setAttribute(“Item“,ItemValue);//设置一个应用变量
Integeri=(Integer)getServletContext().getAttribute(“ItemName“);//得到//item
[下一页]
五、ServerSideIncludes
在服务器端引用上ASP和JSP有着相同之处。ASP和JSP都可以支持此功能的服务器(IIS,APACHE)上实现服务器端包含虚文件。但JSP是将动态页面的结果包含进来,而不是包含文件的代码本身。当你包含的文件在另一个服务器上时,不包含任何代码和对象是一个非常有效的功能。
ASP:
JSP:< %@includefile=“subfile.jsp“-- >
六、JAVA组件:JavaBeans
JavaBeans是一些完成预定义功能的封装的对象数据。JavaBeans和JSP接合与COM和ASP相比如下:
COM对象常用来封装商业逻辑和为ASP页面完成高强度计算。重用的组件使得页面简单快速,因为组件由编译语言(C++,VB)构成,而不是解释型的s cripting语言(VBs cript, Js cript)。
JavaBeans只能用java语言开发,com可以由符合标准对象模型的任何语言开发(包括Visual J++)。另一方面,JavaBeans更容易开发,因为一旦掌握了java,了解JavaBeans的结构非常容易。由于com的复杂性,需要大量的学习和培训才能掌握--即使你具有c++和vb的基础也需要额外的努力。Com 组件需要在服务器上注册,如果你修改了一个现有的组件,服务器需要重新启动才能使用它。JavaBeans不需要重新注册,如果开发者不需要得到对服务器的完全访问权限,这是其一个巨大的优点。
可以创建满足商业逻辑的完整的JavaBeans库,让非编程人员使用库来开发动态网站。
Beans可以在服务器端管理数据库连接。
JavaBeans符合结构化对象模型:每个Bean由一个不带参数的构造函数,控制它的servlet可以使用内省(introspection)来设置其属性。要设置Bean的内置属性,必须使用带有属性名的setProperty标签。如果一个属性可以设置,Bean需要有一个setXxxx方法,Xxxx用实际的属性名来代替。
七、JSP和数据库
ASP使用ODBC通过ADO连接数据库,而JAVA通过一个叫JDBC的技术联接数据库。目标数据库需要一个JDBC驱动程序--一个数据库与JAVA的借口,使得JAVA可以用标准的方式访问数据库。JDBC不使用服务器端的数据源。只要有JDBC驱动程序,JAVA就可以访问数据库了。如果一个特定的数据库没有JDBC驱动程序,而只有ODBC驱动程序,JAVA提供一个JDBC-ODBC桥来将JDBC调用转化为ODBC调用。所有的JAVA编译器都带有一个**的JDBC-ODBC桥。理论上,桥可以访问任何常见的数据库产品。
结论:JSP模型是在ASP之后定义的,它借用了ASP的许多优点,如Session,Application等对象。同时JSP使用灵活而强大的JAVA语言,而不是低效的s cripting语言。ASP开发者只能使用基于windows平台的技术,而java和jsp是跨平台的。
Google:maps JSP Taglibrary
利用Google:maps JSP标签库就能够在你的Web站点上实现GoogleMaps的所有功能,而且不需要javascript或AJAX编程。它还能够与JSTL相结合生成数据库驱动的动态Maps。
目前,Jsp作为一个很好的动态网站开发语言得到了越来越广泛的应用,在各类Jsp应用程序中,Jsp
+ Java Bean的组合成为了一种事实上最常见的Jsp程序的标准,就让我们来看看具体的Jsp是如何与
Java Bean结合在一起的吧。
本教程将阐述JavaBean的原理,接着将阐述JavaBean在JavaServer Page下的特定语法,然后
演示一个使用Jsp+JavaBean的简单的计数器,最后将详细的讲解一个有数据库功能的JavaBean+jsp
的用户注册程序。
Java Bean原理与应用
1、什么是JavaBean?
JavaBean是描述Java的软件组件模型,有点类似于Microsoft的COM组件概念。在Java模型中,
通过JavaBean可以无限扩充Java程序的功能,通过JavaBean的组合可以快速的生成新的应用程序。
对于程序员来说,最好的一点就是JavaBean可以实现代码的重复利用,另外对于程序的易维护性等等
也有很重大的意义。
JavaBean通过Java虚拟机(Java Virtual Machine)可以得到正确的执行,运行JavaBean最
小的需求是JDK1.1或者以上的版本。
JavaBean传统的应用在于可视化的领域,如AWT下的应用。自从Jsp诞生后,JavaBean更多的应
用在了非可视化领域,在服务器端应用方面表现出来了越来越强的生命力。在这里我们主要讨论的是非
可视化的JavaBean,可视化的JavaBean在市面上有很多Java书籍都有详细的阐述,在这里就不作为
重点了。
2、非可视化的JavaBean
非可视化的JavaBean,顾名思义就是没有GUI界面的JavaBean。在Jsp程序中常用来封装事务逻
辑、数据库操作等等,可以很好地实现业务逻辑和前台程序(如jsp文件)的分离,使得系统具有更好的
健壮性和灵活性。
一个简单的例子,比如说一个购物车程序,要实现购物车中添加一件商品这样的功能,就可以写
一个购物车操作的JavaBean,建立一个public的AddItem成员方法,前台Jsp文件里面直接调用这个
方法来实现。如果后来又考虑添加商品的时候需要判断库存是否有货物,没有货物不得购买,在这个
时候我们就可以直接修改JavaBean的AddItem方法,加入处理语句来实现,这样就完全不用修改前台
jsp程序了。
当然,也可以把这些处理操作完全写在jsp程序中,不过这样的jsp页面可能就有成百上千行,光看
代码就是一个头疼的事情,更不用说修改了。如果您使用过asp开发过程序的话,相信对这就深有体会
了(其实使用ASP+COM组件完全可以实现同jsp+javabean同样的架构,但不知道某种原因网上常见的
都是全部写在asp页面中,所以使得维护修改等极为不方便,当然这是题外话了)。由此可见,通过
JavaBean可以很好地实现逻辑的封装、程序的易于维护等等。
如果您使用Jsp开发程序,一个很好的习惯就是多使用JavaBean。
3、JavaBean的简单例子
创建JavaBean并不是一件困难的事情,如果您写过Java程序的话那就很容易了,要注意一点的
就是在非可视化JavaBean中,常用>get或者>set这样的成员方法来处理属性>(properties>)。>
下面让我们来看一个简单的JavaBean
FirstJavaBean.java
import java.io.*;
public class FirstJavaBean {
private String FirstProperty = new String("");
public FirstJavaBean() {
}
public String getFirstProperty() {
return FirstProperty;
}
public void setFirstProperty(String value) {
FirstProperty = value;
}
public static void main(String[] args)
{
System.out.println("My First JavaBean!");
}
}
如果运行这个程序,就会出现下面的结果:
First JavaBean!
这是一个很典型的JavaBean的代表,简单地解释一下,FirstProperty是其中的一个属性
(Property),外部通过get/set方法可以对这个属性进行操作,如果您写过VB的class的话,对
这个就再也熟悉不过了。Main方法是为了测试程序用的,写JavaBean可以先不必加入到Jsp程序中
调用,而直接用main方法来进行调试,调试好以后就可以在Jsp程序中调用了。
Jsp + JavaBean循序渐进教程(二)
(文/刘玉锋)
JavaBeans 和 JavaServer Pages的结合
通过上面的学习,大家对JavaBean应该有了一个基本的了解,对于在JavaServer Pages中调用
JavaBeans我们还需要了解一些特定的jsp的内容,让我们来看看吧。
JavaServer Pages中的JavaBean相关标签
在JavaServer Pages中调用JavaBean有三个标准的标签,那就是,
,以及。
标签
可以定义一个具有一定生存范围以及一个唯一id的JavaBean的实例,这样
JavaServer Pages通过id来识别JavaBean,也可以通过id.method类似的语句来操作JavaBean。
在执行过程中,首先会尝试寻找已经存在的具有相同id和scope值的JavaBean实例,
如果没有就会自动创建一个新的实例。
其具体语法如下
body
其中,typeSpec定义如下
typeSpec ::=class=“className”
/ class=“className” type=“typeName”
/ type=“typeName” class=“className”
/ beanName=“beanName” type=“typeName”
/ type=“typeName” beanName=“beanName”
/ type=“typeName”
下面的表格是标签中相关属性的含义
属性及定义
Id
id属性是JavaBean对象的唯一标志,代表了一个JavaBean对象的实例。它具有特定的存在范围
(page/request/session/application)。在JavaServer Pages中通过id来识别JavaBean。
Scope
Scope属性代表了Javabean对象的生存时间,可以是page, request, session, 和
application中的一种。
Class
代表了JavaBean对象的class名字,特别注意大小写要完全一致。
beanName
BeanName属性代表了Bean的名字,通常通过java.beans.Beans class的instantiate() 方法
来初始化。.
Type
Type属性指定了脚本变量定义的类型,默认为脚本变量定义和class中的属性一致,一般我们都
采用默认值
标签
另一个标准的标签就是标签了,它主要用于设置bean的属性值。JavaServer
Pages中调用的语法如下:
其中,name属性代表了已经存在的并且具有一定生存范围(scope)的JavaBean实例。last_syntax
代表的语法如下: property=“*” /
property=“propertyName” /
property=“propertyName” param=“parameterName” /
property=“propertyName” value=“propertyValue”
下面是标签的基本属性以及含义
属性及定义
Name
Name代表通过 标签定义的JavaBean对象实例。 Property
这是个很重要的属性,代表了你想设置值的属性property名字。如果使用property=”*”,程序就会
反复的查找当前的ServletRequest所有参数,并且匹配JavaBean中相同名字的属性property,并通过
JavaBean中属性的set方法赋值value给这个属性。如果value属性为空,则不会修改Javabean中的
属性值。
Param
Param属性代表了页面请求的参数名字,标签不能同时使用param和value。
Value
Value属性代表了赋给Bean的属性property的具体值。
标签
最后一个标签就是标签了.它可以得到JavaBean实例的属性值,并将他们转换为
java.lang.String, 最后放置在隐含的Out对象中. JavaBean的实例必须在
前面定义.
标签的语法如下:
下面是标签的基本属性以及含义
属性及定义
Name
Name属性代表了想要获得属性值的Bean的实例,Bean实例必须在前面用标签定义.
Property
Property属性代表了想要获得值的那个property的名字。
Jsp + JavaBean循序渐进教程(三)
刘玉锋?yesky
Jsp与JavaBean结合的简单例子
上面讲了这么多,到现在还没有看到具体应用,那好,现在我们看看具体的JavaServer Pages+JavaBean
的例子吧,首先让我们看看一个简单的计数器程序。
本例程共包含3个文件
JavaBean--counter.java文件,JavaServer Page-- counter.jsp文件, counter1.jsp文件其中,
counter.java主要用来进行计数器的计数操作,counter.jsp和counter1.jsp文件主要用来显示网页的计数。
counter.java文件
package count;
/**
* Title: test
* Description: counter Bean
* @author LiuYufeng
* @version 1.0
*/
public class counter {
//初始化JavaBean的成员变量
int count = 0;
// Class构造器
public counter() {
}
// 属性Count的Get方法
public int getCount() {
//计数操作,每一次请求都进行计数器加一
count++;
return this.count;
}
//属性Count的Set方法
public void setCount(int count) {
this.count = count;
}
}
counter.jsp文件
< HTML>
< HEAD>
< TITLE>
counter
< /TITLE>
< /HEAD>
< BODY>
< H1>
JBuilder Generated JSP
< /H1>
< jsp:useBean id="bean0" scope="application" class="count.counter" />
< /BODY>
< /HTML>
counter1.jsp文件
< HTML>
< HEAD>
< TITLE>
counter
< /TITLE>
< /HEAD>
< BODY>
< H1>
JBuilder Generated JSP
< /H1>
The Counter is :
< /BODY>
< /HTML>
从这个例子我们不难看出Jsp和JavaBean应用的一般操作方法,首先在Jsp页面中要声明并初始化JavaBean,
这个JavaBean有一个唯一的id标志,还有一个生存范围scope(设置为application是为了实现多个用户共享
一个计数器的功能,如果要实现单个用户的计数功能,可以修改scope为session),最后还要制定JavaBean的
class来源count.counter:
接着我们就可以使用JavaBean提供的public方法或者直接使用标签来得到JavaBean
中属性的值:
out.println("The Counter is : " + bean0.getCount() + "");
或者
OK,现在运行一下程序看看,然后多刷新几次,注意看计数器的变化。上面的程序在Jbuilder4.0下面
调试通过。
如果要直接在一些jsp环境(如Tomcat、IAS、Weblogic等)下调试,请注意各自的文档,正确的放置
JavaBean文件。如在Tomcat环境中,本例子JavaBean编译后的文件就需要放在
WEB-INFClASSES count counter.class。
Jsp + JavaBean循序渐进教程(四)上
刘玉锋
-
JavaBeans 和 JavaServer Pages的结合
JavaServer Pages+JavaBeans的数据库操作应用
上面已经讲了一个简单的JavaBean应用的计数器例子,当然在实际程序过程中,涉及的更多的还是和数据库
相关的操作,所以在这一节我们将重点阐述JavaServer Pages和JavaBeans如何对数据库进行操作。这里我们
选取了一个比较有代表性比较实用的例子,那就是用户注册管理,因为这在网上使用比较的频繁,不管是注册
Email、有奖调查、购买物品或者加入社区等等都会涉及到一个用户注册的问题;另外一方面,它又比较有代表性,
涉及到了数据库的记录增加,记录显示等常见操作,所以我们就拿用户注册开刀了。
程序采用Oracle Jdeveloper3.1开发,运行环境为Wiin2000+Tomcat3.1,数据库系统采用了Oracle8.16i。
首先我们建立一个数据库demodb,其字段如下面所示
username VARCHAR2(20) 用户名
password VARCHAR2(20) 密码
email VARCHAR2(30) Email地址
homepage VARCHAR2(50) 主页
signs VARCHAR2(200) 签名
regtime DATE 注册时间
接着我们建立几个JavaBeans和JavaServer Pages文件
db.java文件(封装数据库连接及一些底层操作)
adduser.java文件(进行用户数据的读取以及添加操作)
newuser.jsp文件(用户新增页面,用于输入用户注册信息)
donewuser.jsp文件(进行用户注册信息添加)
listuser.jsp文件(所有的注册用户信息列表)
为了方便大家看代码,在很多地方都进行了详细的注释和讲解,至于JavaBean中涉及到Java语法结构的东西,
请大家参考Java书籍。
db.java文件
说明:这个JavaBean封装数据库连接及一些底层操作,派生出的类可以直接调用这些方法,另外提供了一个
toChinese方法,主要用来进行中文数据的处理。
// Copyright (c) 2000 http://jspbbs.yeah.net
package lyf;
/**
* A Class class.
* < P>
* @author liuyufeng
*/
//声明类库文件
import oracle.jdbc.driver.*;
import java.net.*;
import java.sql.*;
import java.lang.*;
import java.io.*;
import java.util.*;
public class db {
//成员变量初始化
Connection conn = null; //数据库连接
ResultSet rs = null; //记录集
String Username=""; //用户名
String Password=""; //密码
String Email=""; //email
String Homepage=""; //主页
String Signs=""; //签名
//db的构建器
public db() {
try {
//注册数据库驱动程序为Oracle驱动
Class.forName(new oracle.jdbc.driver.OracleDriver());
}
catch(java.lang.ClassNotFoundException e) {
//这样写是为了方便调试程序,出错打印mydb()就知道在什么地方出错了
System.err.println("mydb(): " + e.getMessage());
}
}
//executeQuery方法用于进行记录的查询操作
//入口参数为sql语句,返回ResultSet对象
public ResultSet executeQuery(String sql) {
rs = null;
try {
//建立数据库连接,使用Oracle的一种thin连接方式,demo为主机名字,demodb为数据库,后面的两个
demo为用户名和密码
conn = DriverManager.getConnection("jdbc:oracle:thin:@demo:1521:demodb","demo","demo");
Statement stmt = conn.createStatement();
//执行数据库查询操作
rs = stmt.executeQuery(sql);
}
catch(SQLException ex) {
System.err.println("db.executeQuery: " + ex.getMessage());
}
return rs;
}
//executeUpdate方法用于进行add或者update记录的操作
//入口参数为sql语句,成功返回true,否则为false
public boolean executeUpdate(String sql) {
boolean bupdate=false;
rs = null;
try {
//建立数据库连接,其它参数说明同上面的一样
conn = DriverManager.getConnection("jdbc:oracle:thin:@demo:1521:demodb","demo","demo");
Statement stmt = conn.createStatement();
int rowCount = stmt.executeUpdate(sql);
//如果不成功,bupdate就会返回0
if(rowCount!=0)bupdate=true;
}
catch(SQLException ex) {
//打印出错信息
System.err.println("db.executeUpdate: " + ex.getMessage());
}
return bupdate;
}
//toChinese方法用于将一个字符串进行中文处理
//否则将会是???这样的字符串
public static String toChinese(String strvalue) {
try{
if(strvalue==null)
{
return null;
}
else
{
strvalue = new String(strvalue.getBytes("ISO8859_1"), "GBK");
return strvalue;
}
}catch(Exception e){
return null;
}
}
}
Jsp + JavaBean循序渐进教程(四)下
刘玉锋
adduser.java文件
说明:主要进行用户数据的读取以及添加操作,从db派生出来,addNewUser方法用来进行用户数据的
添加,checkUser()方法用来检查用户名是否重复,另外还有一些set/get方法用来对属性进行处理,
dousernew.jsp文件将进行条用。
// Copyright (c) 2000 http://jspbbs.yeah.net
package lyf;
/**
* A Class class.
*
* @author liuyufeng
*/
//导入java类库
import java.sql.*;
import java.lang.*;
import oracle.jdbc.driver.*;
//adduser由db派生出来,拥有db的成员变量和方法
public class adduser extends db {
//构建器
public boolean addNewUser(){
boolean boadduser=false;
try {
//进行用户注册的记录添加操作,生成sql语句
String sSql=new String("insert into user(regtime,username,password,email,homepage,
signs)");
sSql=sSql+ " values(SYSDAYE,""+Username+"",""+Password+"",""+Email+"",""+Homepage
+"",""+Signs+"")";
//一种调试的方法,可以打印出sql语句,以便于查看错误
System.out.println(sSql);
//调用父类的executeUpdate方法,并根据成功以否来设置返回值
if(super.executeUpdate(sSql))boadduser=true;
}
catch(Exception ex) {
//出错处理
System.err.println("adduser.addNewUser: " + ex.getMessage());
}finally{
//无论是否出错,都要返回值
return boadduser;
}
}
//checkUser()方法用来检查用户名是否重复
//如果重复返回一个false
public boolean checkUser(){
boolean boadduser=false;
try {
//构建sql查询语句
String sSql="select * from user where username=""+Username+""";
//调用父类的executeQuery方法
if((super.executeQuery(sSql)).next()){
//查询出来的记录集为空
boadduser=false;
}else{
boadduser=true;
}
}
catch(Exception ex) {
//出错处理
System.err.println("adduser.addNewUser: " + ex.getMessage());
}finally{
//返回值
return boadduser;
}
}
//属性的set/get方法,同请求的参数一致
/*
其实下面的所有get/set方法都是重复性劳动,为了避免重复性的拷贝粘贴工作,我写了个软件
Jsp Code Faster,只要输入一系列的字段名,所有的get/set方法都可以自动生成,大家可以在我的网站
http://jspbbs.yeah.net上下载这个软件
*/
//属性用户名Username的get/set方法
public String getUsername(){
return Username;}
public void setUsername(String newUsername){
//用户名有可能是中文,需要进行转换
Username =db.toChinese(newUsername);}
//属性密码Password的get/set方法
public String getPassword(){
return Password;}
public void setPassword(String newPassword){
Password = newPassword;}
//属性Email的get/set方法
public String getEmail(){
return Email;}
public void setEmail(String newEmail){
Email = newEmail;}
//属性主页Homepage的get/set方法
public String getHomepage(){
return Homepage;}
public void setHomepage(String newHomepage){
Homepage = newHomepage;}
//属性主页Signs的get/set方法
public String getSigns(){
return Signs;}
public void setSigns(String newSigns){
//签名有可能是中文,需要进行转换
Signs = db.toChinese(newSigns);}
}
好了,到这里,Javabean程序基本上写完了,要注意的是中文处理一定要经过转换,还有不一定所有
的属性都需要set/get方法,视情况而定,最后还需要编译为class文件,可以使用一些可视化的软件如
Jbuilder或者VisualAge等等来编译。编译后会发现有两个文件db.class和adduser.class文件,都
在lyf子目录下。这两个文件就可以让后面的jsp页面调用了。
Jsp+JavaBean循序渐进教程(五)
刘玉锋
newuser.jsp文件
说明:用户注册页面,有用户名、密码、主页、Email、个人签名等信息,主要用于提供用户输入注册
信息,提交Action后的处理页面为donewuse.jsp文件,所有参数将会传递到donewuser.jsp文件进行
处理。文件开头< %@ page contentType="text/html;charset=gb2312"%>语句表明这个页面使用
gb2312中文字符集,如果不声明的的话在中文显示上就出现乱码。< % response.setHeader("Expires",
"0"); %>语句是为了让页面能够自动刷新,这句话不要也没有太大影响。后面的基本上就是html语句了,
大家都比较熟悉,所以在这里没有必要浪费篇幅了。
< %@ page contentType="text/html;charset=gb2312"%>
< % response.setHeader("Expires","0"); %>
< html>
< head>
< meta http-equiv="Content-Type" content="text/html; charset=gb2312">
< meta name="GENERATOR" content="Microsoft FrontPage 4.0">
< meta name="ProgId" content="FrontPage.Editor.Document">
< title>新用户注册
< /head>
< body bgcolor="#FFFAD9">
< p align="center">< font color="#8484FF">< span class="main1">< strong>< big>新个人
用户注册
< span class="main1">
< form method="POST" name="formreg" action="donewuser.jsp">
< div align="center">< center>< table
border="1" width="50%" borderColorDark="#FFFFFF" borderColorLight="#000000"
cellspacing="0">
< tr>
< td width="27%" bgcolor="#DDDDFF" align="center">< span class="main1">用户名:
< td width="73%" bgcolor="#DDDDFF">< span class="main1">< input type="text"
name="username" size="20"
tabindex="2">< font color="#FF0000">< b>*
< /tr>
< tr>
< td width="27%" bgcolor="#DDDDFF" align="center">输入密码:
< td width="73%" bgcolor="#DDDDFF">< input type="password" name="password" size="20"
tabindex="2">< font color="#FF0000">< b>*
< /tr>
< tr>
< td width="27%" bgcolor="#DDDDFF" align="center">校验密码:
< td width="73%" bgcolor="#DDDDFF">< input type="password" name="Password1" size="20"
tabindex="3">< font color="#FF0000">< b>*
< /tr>
< tr>
< td width="27%" bgcolor="#DDDDFF" align="center">E-mail
< td width="73%" bgcolor="#DDDDFF">< input type="text" name="email" size="20" tabindex="4">
< font color="#FF0000">*
< /tr>
< tr>
< td width="27%" bgcolor="#DDDDFF" align="center">主页地址:
< td width="73%" bgcolor="#DDDDFF">< input type="text" name="homepage" size="20"
tabindex="6" value="http://">
< /tr>
< tr>
< td width="100%" bgcolor="#DDDDFF" colspan="2">
< BR>
< center>< span class="main1">< Font color="red">< B>介绍自己:
< span class="main">(介绍自己,不能超过120字)
< /tr>
< tr>
< td width="100%" bgcolor="#DDDDFF" colspan="2"> < textarea rows="6"
name="signs" cols="66" tabindex="9">
< /tr>
< tr>
< td width="30%" bgcolor="#DDDDFF" colspan="2">< center>< p>< input
type="submit" value="递交" onclick="return checkmsg();" name="B1" tabindex="10">
< input type="reset" value="清除" name="B2" tabindex="11">
< /tr>
< /table>
< /center>
< /form>
< hr size="1" color="#FF0000">
< span class="main">
< p align="center">Better View:800*600 Best View:1024x768
为了本系统能够更好的为您服务,请使用IE4.0或以上版本浏览器
< font color="#000000">< a href="javascript:%20newGuide("copyright.htm")"
target="_self">版权所有
< span class="main">
< a href="http://jspbbs.yeah.net" target="_blank">JSP爱好者
< span class="main1">(< a href="mailto:coolknight@263.net">刘玉锋)
制作 Copyright? 2000
< /body>
< /html>
注册页面做完了,看看后面怎么对这个页面的数据进行处理。
Jsp+JavaBean循序渐进教程(六)
刘玉锋
这一节涉及到两个页面,一个donewuser.jsp文件用来实现记录添加操作,另一个文件listuser.jsp文件
用来显示所有的已经注册的用户信息。这两个页面都涉及到了JavaBean的具体调用,还是来看看文件吧,
对于文件中关键代码,都会添加上注释,以方便大家理解。
donewuser.jsp文件
说明:用户注册操作页面,并根据用户注册成功否显示相应的反馈信息,这个页面主要的特点就是使用了
lyf.adduser这个JavaBean的addNewUser()方法来进行记录的添加。
< %@ page contentType="text/html;charset=gb2312"%>
< % response.setHeader("Expires","0"); %>
< !--生成一个JavaBean:lyf.adduser的实例,id为adduser,生存范围为page-->
< jsp:useBean id="adduser" class="lyf.adduser" scope="page"/>
< !--设置JavaBean中各个属性的值,这会调用JavaBean中各个属性的set方法,以便JavaBean得到
正确的属性值,”*”代表进行所有属性的匹配-->
< jsp:setProperty name="adduser" property="*"/>
< html>
< head>
< meta http-equiv="Content-Language" content="zh-cn">
< meta http-equiv="Content-Type" content="text/html; charset=gb2312">
< meta name="GENERATOR" content="Microsoft FrontPage 3.0">
< meta name="ProgId" content="FrontPage.Editor.Document">
< title>用户添加< /title>
< /head>
< body bgcolor="#FFEBBD">
< div align="center">< center>
< %
//调用lyf.adduser的checkUser()方法检查是否有重复的用户名
//如果有重复就显示对应的信息
if(!adduser.checkUser())
{
//页面文字输出信息,使用jsp内置对象out的println方法,相当于asp中的response.write方法
out.println("对不起,这个用户名"+adduser.getUsername()+"已经被申请了,请重新选择!");
//return代表返回,运行时候碰到return就不会进行下面的处理了,功能相当于asp中的response.end
return;
}
%>
< %
//如果没有用户名重复的问题,调用lyf.adduser的addNewUser()方法来将用户数据添加到数据库中,并
根据数据添加成功否来显示对应的信息
if(adduser.addNewUser()){
%>
< H2>添加用户成功!
< H2>添加用户失败,请和管理员联系!
< /BODY>
< /HTML>
listuser.jsp文件
说明:用户信息列表页面,用于显示注册的所有用户信息,对数据进行了分页显示。
为了方便大家使用,采用了通用的分页代码,如果是JDBC2.0以上或者其他支持
TYPE_SCROLL_INSENSITIVE游标的数据库驱动程序,可以有更简洁的分页方法。
和前面jsp页面类似的语句就不讲解了,代表在
这个页面中导入java.sql.ResultSet的这个类库,因为Jsp页面中间要声明ResultSet;
oracle.jdbc.driver.*类库是Oracle专用的Jdbc驱动程序,让Jsp页面可以用来进行Oracle的数据库操作。
< %@ page contentType="text/html;charset=gb2312"%>
< % response.setHeader("Expires","0"); %>
< %@ page import="java.sql.ResultSet" %>
< %@ page import="oracle.jdbc.driver.*" %>
< !--生成一个JavaBean:lyf.db的实例-->
< jsp:useBean id="db" class="lyf.db" scope="request"/>
< jsp:setProperty name="db" property="*"/>
< %
java.lang.String strSQL; //SQL语句
int intPageSize; //一页显示的记录数
int intRowCount; //记录总数
int intPageCount; //总页数
int intPage; //待显示页码
java.lang.String strPage;
int i,j,k;
//设置一页显示的记录数
intPageSize = 15;
//取得待显示页码
strPage = request.getParameter("page");
if(strPage==null){//表明在QueryString中没有page这一个参数,此时显示第一页数据
intPage = 1;
}
else{//将字符串转换成整型
intPage = java.lang.Integer.parseInt(strPage);
if(intPage<1) intPage = 1;
}
//获取记录总数
strSQL = "select count(*) from user";
ResultSet result = db.executeQuery(strSQL); //执行SQL语句并取得结果集
result.next(); //记录集刚打开的时候,指针位于第一条记录之前
intRowCount = result.getInt(1);
result.close(); //关闭结果集
//记算总页数
intPageCount = (intRowCount+intPageSize-1) / intPageSize;
//调整待显示的页码
if(intPage>intPageCount) intPage = intPageCount;
strSQL="select * from user order by id desc";
//执行SQL语句并取得结果集
result = db.executeQuery(strSQL);
//将记录指针定位到待显示页的第一条记录上
i = (intPage-1) * intPageSize;
for(j=0;j
< html>
< head>
< meta http-equiv="Content-Language" content="zh-cn">
< meta http-equiv="Content-Type" content="text/html; charset=gb2312">
< meta name="GENERATOR" content="Microsoft FrontPage 3.0">
< meta name="ProgId" content="FrontPage.Editor.Document">
< title>用户列表< /title>
< /head>
< body bgcolor="#FFEBBD">
< div align="center">< center>
< table border="1"
borderColorDark="#FFFFFF" borderColorLight="#000000" cellspacing="0" height="22"
width="100%">
< tr bgcolor="#FFEBAD">
< td height="1" width="691" class="main">
第页 共页
< a href="listuser.jsp?page=0">首页
< a href="listuser.jsp?page=">上一页
上一页
< a href="listuser.jsp?page=">下一页
下一页
< a href="listuser.jsp?page=">尾页
第< input type="text" class="main" name="page" size="3" value=""
tabindex="1">页< input type="submit" class="main" value="go" name="B1" tabindex="2">
< table border="1" width="100%" cellspacing="0" bordercolorlight="#000000"
bordercolordark="#FFFFFF" class="main">
< tr bgcolor="#FFEBAD">
< td >
< div align="left">用户名
< td >
< p align="center">Email
< td >
< p align="center">主页
< td>
< p align="center">登记时间
< td>
< p align="center">说明
< tr bgcolor="#FFEBAD">
< td>
< div align="left">
< td>< div align="center">
< td>< div align="center">< font color="#0000CC">
< td>< div align="center">< font color="#FF6666">
< td>< div align="center">< font color="#0000FF">
< /table>
< /body>
< /html>
先运行程序newuser.jsp文件,进行用户注册操作,然后运行listuser.jsp文件,看看是否已经
添加到数据库中。对于具体jsp文件和class文件放在什么目录下的问题,请看具体jsp服务器软件的参考,
一个最简单的方法就是用Jbuilder4.0直接运行,因为它自带了Tomcat服务器软件。
好了,到这里Jsp+JavaBean的介绍就基本上结束了,通过上面的学习,大家应该对JavaBean如何
应用于JSP程序中有了一个基本的了解,剩下的就是在具体程序中去应用和发挥了。
JavaServer Pages+JavaBeans的数据库操作应用
上面已经讲了一个简单的JavaBean应用的计数器例子,当然在实际程序过程中,涉及的更多的还是和数据库相关的操作,所以在这一节我们将重点阐述JavaServer Pages和JavaBeans如何对数据库进行操作。这里我们选取了一个比较有代表性比较实用的例子,那就是用户注册管理,因为这在网上使用比较的频繁,不管是注册Email、有奖调查、购买物品或者加入社区等等都会涉及到一个用户注册的问题;另外一方面,它又比较有代表性,涉及到了数据库的记录增加,记录显示等常见操作,所以我们就拿用户注册开刀了。
程序采用Oracle Jdeveloper3.1开发,运行环境为Wiin2000+Tomcat3.1,数据库系统采用了Oracle8.16i。
首先我们建立一个数据库demodb,其字段如下面所示
username VARCHAR2(20) 用户名
password VARCHAR2(20) 密码
email VARCHAR2(30) Email地址
homepage VARCHAR2(50) 主页
signs VARCHAR2(200) 签名
regtime DATE 注册时间
接着我们建立几个JavaBeans和JavaServer Pages文件
db.java文件(封装数据库连接及一些底层操作)
adduser.java文件(进行用户数据的读取以及添加操作)
newuser.jsp文件(用户新增页面,用于输入用户注册信息)
donewuser.jsp文件(进行用户注册信息添加)
listuser.jsp文件(所有的注册用户信息列表)
为了方便大家看代码,在很多地方都进行了详细的注释和讲解,至于JavaBean中涉及到Java语法结构的东西,请大家参考Java书籍。
db.java文件
说明:这个JavaBean封装数据库连接及一些底层操作,派生出的类可以直接调用这些方法,另外提供了一个toChinese方法,主要用来进行中文数据的处理。
【赛迪网讯】随着网站的不断扩大,首页面的内容越来越多,甚至要放置赢利性质的广告,而这些内容,每次被用户访问时都是从数据库中读取或者经过业务逻辑处理获得结果,这样会严重影响页面的加载速度,很多网站都是使用静态的html首页面来结局问题。
实现过程
1. 创建jsp页面,添加测试内容
2. 编写MyOutputStream类他继承自ServletOutputStream类并重写write()方法,使用自己的字节数组输出流实现了数据输出。关键代码如下:
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import javax.servlet.ServletOutputStream;
public class MyOutputStream extends ServletOutputStream {
private ByteArrayOutputStream stream;
public MyOutputStream(ByteArrayOutputStream stream){
this.stream=stream;
}
@Override
public void write(int arg0) throws IOException {
// TODO Auto-generated method stub
stream.write(arg0);
}
}
3. 编写ResponseWrapper类,他继承自HttpServletResponseWrapper类,并重写getOutputStream()和getWriter()方法,返回本类定义的输出流,自定义的的getContent()方法可以获取这些输出流的数据。关键代码如下。
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpServletResponseWrapper;
import com.stream.MyOutputStream;
public class ResponseWrapper extends HttpServletResponseWrapper {
private MyOutputStream stream;
private ByteArrayOutputStream byteStream;
private PrintWriter pw;
public ResponseWrapper(HttpServletResponse response) {
super(response);
// TODO Auto-generated constructor stub
this.byteStream=new ByteArrayOutputStream();
this.stream=new MyOutputStream(this.byteStream);
this.pw=new PrintWriter(this.byteStream);
}
@Override
public ServletOutputStream getOutputStream() throws IOException {
// TODO Auto-generated method stub
return stream;
}
@Override
public PrintWriter getWriter() throws IOException {
// TODO Auto-generated method stub
return this.pw;
}
public String getContent(){
//取出空格,必须否则在页面中会有其他字符
return this.byteStream.toString().trim();
}
}
4. 编写CreateHTMLFilter过滤器,实现Filter接口,在doFilter()方法中实现业务。
import java.io.DataOutputStream;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.Date;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import com.stream.MyOutputStream;
import com.wrapper.ResponseWrapper;
/**
* Servlet Filter implementation class CreateHTMLFilter
*/
public class CreateHTMLFilter implements Filter {
/**
* Default constructor.
*/
public CreateHTMLFilter() {
// TODO Auto-generated constructor stub
}
/**
* @see Filter#destroy()
*/
public void destroy() {
// TODO Auto-generated method stub
}
/**
* @see Filter#doFilter(ServletRequest, ServletResponse, FilterChain)
*/
public void doFilter(ServletRequest request, ServletResponse response,
FilterChain chain) throws IOException, ServletException {
// TODO Auto-generated method stub
// place your code here
HttpServletResponse res = (HttpServletResponse) response;
ResponseWrapper wrapper = new ResponseWrapper(res);
// pass the request along the filter chain
chain.doFilter(request, wrapper);
wrapper.getWriter().flush();
HttpServletRequest req = (HttpServletRequest) request;
String path = req.getSession().getServletContext()
.getRealPath("index.jsp");
System.out.println(path);
File file = new File(path);
// 创建要生成的html页面对象
File htmlFile = new File(file.getParentFile(), "index.html");
// html页面创建时间
Date htmlDate = null;
Date now = new Date();
if (!htmlFile.exists()) {
htmlFile.createNewFile();
} else {
htmlDate = new Date(htmlFile.lastModified());
}
// 根据文件的创建时间判断是否需要新建html页面
if (htmlDate == null || htmlDate.getDate() != now.getDate()) {
FileOutputStream fos = new FileOutputStream(htmlFile);
DataOutputStream dos = new DataOutputStream(fos);
System.out.println(wrapper.getContent().trim());
dos.writeUTF(wrapper.getContent());
dos.close();
}
request.getRequestDispatcher("index.html").forward(request, response);
}
/**
* @see Filter#init(FilterConfig)
*/
public void init(FilterConfig fConfig) throws ServletException {
// TODO Auto-generated method stub
}
}
5. web.xml文件配置如下:
xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
id="WebApp_ID" version="2.5">
dynamic
index.jsp
CreateHTMLFilter
CreateHTMLFilter
com.filter.CreateHTMLFilter
CreateHTMLFilter
/*
6. 测试,可以看到你想要的结果了
免责声明:
本站系本网编辑转载,会尽可能注明出处,但不排除无法注明来源的情况,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责。如涉及作品内容、版权和其它问题,请在30日内与本网联系, 来信: liujun@soft6.com 我们将在收到邮件后第一时间删除内容!
[声明]本站文章版权归原作者所有,内容为作者个人观点,不代表本网站的观点和对其真实性负责,本站拥有对此声明的最终解释权。

