getPropertyname="bean0"property="count"/>
OK,现在运行一下程序看看,然后多刷新几次,注意看计数器的变化。
上面的程序在Jbuilder4.0下面调试通过。
如果要直接在一些jsp环境(如Tomcat、IAS、Weblogic等)下调试,请注意各自的文档,正确的放置JavaBean文件。
如在Tomcat环境中,本例子JavaBean编译后的文件就需要放在WEB-INFClASSEScountcounter.class。
JavaServerPages+JavaBeans的数据库操作应用
上面已经讲了一个简单的JavaBean应用的计数器例子,当然在实际程序过程中,涉及的更多的还是和数据库相关的操作,所以在这一节我们将重点阐述JavaServerPages和JavaBeans如何对数据库进行操作。
这里我们选取了一个比较有代表性比较实用的例子,那就是用户注册管理,因为这在网上使用比较的频繁,不管是注册Email、有奖调查、购买物品或者加入社区等等都会涉及到一个用户注册的问题;另外一方面,它又比较有代表性,涉及到了数据库的记录增加,记录显示等常见操作,所以我们就拿用户注册开刀了。
程序采用OracleJdeveloper3.1开发,运行环境为Wiin2000+Tomcat3.1,数据库系统采用了Oracle8.16i。
首先我们建立一个数据库demodb,其字段如下面所示:
usernameVARCHAR2(20)用户名
passwordVARCHAR2(20)密码
emailVARCHAR2(30)Email地址
homepageVARCHAR2(50)主页
signsVARCHAR2(200)签名
regtimeDATE注册时间
接着我们建立几个JavaBeans和JavaServerPages文件:
db.java文件(封装数据库连接及一些底层操作)
adduser.java文件(进行用户数据的读取以及添加操作)
newuser.jsp文件(用户新增页面,用于输入用户注册信息)
donewuser.jsp文件(进行用户注册信息添加)
listuser.jsp文件(所有的注册用户信息列表)
db.java文件
说明:
这个JavaBean封装数据库连接及一些底层操作,派生出的类可以直接调用这些方法,另外提供了一个toChinese方法,主要用来进行中文数据的处理。
//Copyright(c)2000
packagelyf;
/**
*AClassclass.
*/
//声明类库文件
importoracle.jdbc.driver.*;
import.*;
importjava.sql.*;
importjava.lang.*;
importjava.io.*;
importjava.util.*;
publicclassdbbr> //成员变量初始化
Connectionconn=null;//数据库连接
ResultSetrs=null;//记录集
StringUsername="";//用户名
StringPassword="";//密码
StringEmail="";//email
StringHomepage="";//主页
StringSigns="";//签名
//db的构建器
publicdb(){
try{
//注册数据库驱动程序为Oracle驱动
Class.forName(neworacle.jdbc.driver.OracleDriver());
}
catch(java.lang.ClassNotFoundExceptione){
//这样写是为了方便调试程序,出错打印mydb()就知道在什么地方出错了
System.err.println("mydb():
"+e.getMessage());
}
}
//executeQuery方法用于进行记录的查询操作
//入口参数为sql语句,返回ResultSet对象
publicResultSetexecuteQuery(Stringsql){
rs=null;
try{
//建立数据库连接,使用Oracle的一种thin连接方式,demo为主机名字,demodb为数据库,后面的两个demo为用户名和密码
conn=DriverManager.getConnection("jdbcracle:
thin:
@demo:
1521:
demodb","demo","demo");
Statementstmt=conn.createStatement();
//执行数据库查询操作
rs=stmt.executeQuery(sql);
}
catch(SQLExceptionex){
System.err.println("db.executeQuery:
"+ex.getMessage());
}
returnrs;
}
//executeUpdate方法用于进行add或者update记录的操作
//入口参数为sql语句,成功返回true,否则为false
publicbooleanexecuteUpdate(Stringsql){
booleanbupdate=false;
rs=null;
try{
//建立数据库连接,其它参数说明同上面的一样
conn=DriverManager.getConnection("jdbcracle:
thin:
@demo:
1521:
demodb","demo","demo");
Statementstmt=conn.createStatement();
introwCount=stmt.executeUpdate(sql);
//如果不成功,bupdate就会返回0
if(rowCount!
=0)bupdate=true;
}
catch(SQLExceptionex){
//打印出错信息
System.err.println("db.executeUpdate:
"+ex.getMessage());
}
returnbupdate;
}
//toChinese方法用于将一个字符串进行中文处理
//否则将会是?
?
?
这样的字符串
publicstaticStringtoChinese(Stringstrvalue){
try{
if(strvalue==null)
{
returnnull;
}
else
{
strvalue=newString(strvalue.getBytes("ISO8859_1"),"GBK");
returnstrvalue;
}
}catch(Exceptione){
returnnull;
}
}
}
adduser.java文件
说明:
主要进行用户数据的读取以及添加操作,从db派生出来,addNewUser方法用来进行用户数据的添加,checkUser()方法用来检查用户名是否重复,另外还有一些set/get方法用来对属性进行处理,dousernew.jsp文件将进行条用。
packagelyf;
//导入java类库
importjava.sql.*;
importjava.lang.*;
importoracle.jdbc.driver.*;
//adduser由db派生出来,拥有db的成员变量和方法
publicclassadduserextendsdb{
//构建器
publicbooleanaddNewUser(){
booleanboadduser=false;
try{
//进行用户注册的记录添加操作,生成sql语句
StringsSql=newString("insertintouser(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(Exceptionex){
//出错处理
System.err.println("adduser.addNewUser:
"+ex.getM