jsp設計模式 | ||
發布日期:2002-04-14 | 作者:bingo | |
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的介紹你可是去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:保護代碼比較好。 .......... 七:結束語 我只是簡單的介紹一下,具體的使用你需要在實際運用中積累,如果需要我的代碼參看,聯系我,如果你覺得寫的和狗屎,非常不好意思,浪費了你寶貴的時間。 |