Jsp + JavaBean
循序渐进教程
(1)
目前,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
循序渐进教程
(
三
)
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-INF\ClASSES\ 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
服务器软件。