jsp設計模式(轉)

post0發表於2007-08-11
jsp設計模式(轉)[@more@]

jsp設計模式

一:介紹

記得初學jsp的時候,總喜歡把他和asp,php去比較,也習慣於使用asp的開發模式去寫jsp,後來才發現這真是很傻的做法,其實jsp一出了來就已經用MVC模式了。下面我就簡要說說jsp設計使用MVC來設計。

二:MVC介紹

MVC 其實是模、檢視、控制的縮寫,也就是說在使用jsp時,有相應的檔案去實現相應的操作。通常jsp只負責view也就是隻負責顯示頁面。業務邏輯等有 bean(ejb)去實現。下面討論的是不使用ejb的情況下實現。如果使用ejb,ejb負責M.C通常會由servlet去實現。或者使用 struts.

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:保護程式碼比較好。

..........

七:結束語

我只是簡單的介紹一下,具體的使用你需要在實際運用中積累,如果需要我的程式碼參看,聯絡我,如果你覺得寫的和狗屎,非常不好意思,浪費了你寶貴的時間。

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/8225414/viewspace-946035/,如需轉載,請註明出處,否則將追究法律責任。

相關文章