JSP设计模式 [转载]

来源:互联网 发布:网络童装代理 编辑:程序博客网 时间:2024/09/21 08:53

一:介绍 

记得初学jsp的时候,总喜欢把他和asp,php去比较,也习惯于使用asp的开发模式去写jsp 
后来才发现这真是很傻的做法,其实jsp一出了来就已经用MVC模式了。下面我就简要说说 
jsp设计使用MVC来设计。

 

二:MVC介绍 
MVC其实是模、视图、控制的缩写,也就是说在使用jsp时,有相应的文件去实现相应的操作 
通常jsp只负责view也就是只负责显示页面。业务逻辑等有bean(ejb)去实现。下面讨论的是 
不使用ejb的情况下实现。如果使用ejb,ejb负责M.C通常会由servlet去实现。或者使用struts. 
struts的介绍你可是去http://jakarta.apache.org/struts去看。以后的文章中我会介绍。

 

三:设计思路 
当你构建一个Application时。你必须考虑界面的问题,而界面修改是非常平常的。如果你在 
jsp中实现所有的操作,一旦修改界面你麻烦大了。美工不懂jsp的,你必须自己去修改无数个 
文件,头不要太大,而此时一般时间都很紧,使用MVC则可以减少你的一些麻烦。 
在设计时候jsp只负责显示页面,也就是说jsp调用Bean(Struts,servlet)传过来的数据然后显示 
而Bean(Struts,servlet)负责收集jsp需要的数据,用ArrayList(Arttibute)传给jsp。假如需要 
提交表单,一般也直接提交给Struts,servlet,处理后以后再返回处理信息。 
而其中相应的业务逻辑由Bean去实现。

 

四:Bean的设计 
在我使用时候Bean通常有三类,分别在manager,entry,database目录下面。 
manager下面的bean做商业逻辑 
entry下的bean就是封装数据,其实就是每个数据库表对应会有一个bean。jsp得到的也全部是类。 
database下的bean就是操作数据库,执行如insert,update,delete,load(查询一条记录), 
batchload(查询多条记录)。 
他们之间的关系是entry负责封装数据,作为database的调用参数,返回结果。 
manager调用database处理的结果。manager和jsp通信。jsp得到的结果从manager来, jsp需要做 
操作调用manager,即使是一个insert 在database存在这样的方法但在manager中你还是需要再封装 
一次。这样做的目的是使结构尽量简单。database只负责操作数据库。manager只做逻辑(取相应的数据) 
处理相应的逻辑,而entry则只把database取到的数据封装,或则把页面得到的参数封装,做为参数 
传给相应的Bean.

 

五:设计实例 
下面我把留言板作为实例来讨论: 
entry/Guestbook.java(留言板对象) 
database/GuestbookMap.java(更新,删除,修改留言板) 
manager/GuestbookManager.java(处理所有的事务) 
数据表结构(postgresql) 
create sequence seq_guestbook increment 1 ; 
/**序列号生成器**/ 
create table guestbook( 
id int8 default nextval(′seq_guestbook′), /**主键**/ 
title varchar(64),/**主题**/ 
body text,/**内容**/ 
sayid int8,/**发言人**/ 
toid int8,/**接受人**/ 
saytime datetime default now(),/**留言时间**/ 
newflg smallint default 1/**是否查看过**/ 
);

Guestbook.java 
======================= 
import java.util.*; 
public class Guestbook(){ 
private int id; 
private String title; 
private body title; 
private int sayid; 
private int sayid; 
private Date saytime; 
private short newflg;

public Guestbook(){

}

public int getId(){ 
return this.id; 
}

public void setId(int _id){ 
this.id=_id; 

........ 
(全是get/set方法) 
}

GuestbookMap.java 
============================== 
import Guestbook; 
public class GuestbookMap(){ 
public GuestbookMap(){

}

public Guestbook load(int id){ 
//取到一条guestbook 

//sqlstr 查询条件 
//orderstr 排序条件 
//rcdbegin 记录开始 
//rcdend 记录结束 
// 
public ArrayList batchLoad(String sqlstr,String orderstr,int rcdbegin,int rcdend){ 
//ArrayList 里面封装了Guestbook 
}

public void insert(Guestbook info){

}

public void update(Guestbook info){

}

public void delete(int id){ 
//取到一条guestbook 
}

public int getRcdNums(String sqlstr){ 
//取记录条数 

}

GuestbookManager.java 
根据需要封装需要的方法,这部分才是你要写的 
============================= 
上面的方式entry,database的文件可以自动生成,这个工具我已经开发了,如果需要联系我。 
你需要写的就是GuestbookManager里面的方法,你也许会觉得工作量比你所有的操作都在jsp中 
大,但是这样结构非常清晰。你还需要的就是写一个数据库连接池,你所有的数据库操作都从一个地方 
取,每一次都去连接数据库开销很大的。

六:技术优势 
1:结构清晰 
2:维护方便 
3:保护代码比较好。 
.......... 
七:结束语 
我只是简单的介绍一下,具体的使用你需要在实际运用中积累,如果需要我的代码参看,联系我, 
如果你觉得写的和狗屎,非常不好意思,浪费了你宝贵的时间