一:介紹
記得初學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){
file://取到一條guestbook
}
file://sqlstr 查詢條件
file://orderstr 排序條件
file://rcdbegin 記錄開始
file://rcdend 記錄結束
//
public ArrayList batchLoad(String sqlstr,String orderstr,int rcdbegin,int rcdend){
file://ArrayList 裡面封裝了Guestbook
}
public void insert(Guestbook info){
}
public void update(Guestbook info){
}
public void delete(int id){
file://取到一條guestbook
}
public int getRcdNums(String sqlstr){
file://取記錄條數
}
}
GuestbookManager.java
根據需要封裝需要的方法,這部分才是你要寫的
上面的方式entry,database的文件可以自動生成,這個工具我已經開發了,如果需要聯系我。你需要寫的就是GuestbookManager裡面的方法,你也許會覺得工作量比你所有的操作都在jsp中大,但是這樣結構非常清晰。你還需要的就是寫一個數據庫連接池,你所有的數據庫操作都從一個地方取,每一次都去連接數據庫開銷很大的。