JSP設(shè)計(jì)模式
發(fā)表時(shí)間:2024-06-05 來源:明輝站整理相關(guān)軟件相關(guān)文章人氣:
[摘要]一:介紹 記得初學(xué)jsp的時(shí)候,總喜歡把他和asp,php去比較,也習(xí)慣于使用asp的開發(fā)模式去寫jsp后來才發(fā)現(xiàn)這真是很傻的做法,其實(shí)jsp一出了來就已經(jīng)用MVC模式了。下面我就簡要說說jsp設(shè)計(jì)使用MVC來設(shè)計(jì)。 二:MVC介紹 MVC其實(shí)是模、視圖、控制的縮寫,也就是說在使用js...
一:介紹
記得初學(xué)jsp的時(shí)候,總喜歡把他和asp,php去比較,也習(xí)慣于使用asp的開發(fā)模式去寫jsp后來才發(fā)現(xiàn)這真是很傻的做法,其實(shí)jsp一出了來就已經(jīng)用MVC模式了。下面我就簡要說說jsp設(shè)計(jì)使用MVC來設(shè)計(jì)。 二:MVC介紹
MVC其實(shí)是模、視圖、控制的縮寫,也就是說在使用jsp時(shí),有相應(yīng)的文件去實(shí)現(xiàn)相應(yīng)的操作
通常jsp只負(fù)責(zé)view也就是只負(fù)責(zé)顯示頁面。業(yè)務(wù)邏輯等有bean(ejb)去實(shí)現(xiàn)。下面討論的是不使用ejb的情況下實(shí)現(xiàn)。如果使用ejb,ejb負(fù)責(zé)M.C通常會(huì)由servlet去實(shí)現(xiàn);蛘呤褂胹truts。struts的介紹你可是去http://jakarta.apache.org/struts去看。以后的文章中我會(huì)介紹。
三:設(shè)計(jì)思路
當(dāng)你構(gòu)建一個(gè)Application時(shí)。你必須考慮界面的問題,而界面修改是非常平常的。如果你在jsp中實(shí)現(xiàn)所有的操作,一旦修改界面你麻煩大了。美工不懂jsp的,你必須自己去修改無數(shù)個(gè)文件,頭不要太大,而此時(shí)一般時(shí)間都很緊,使用MVC則可以減少你的一些麻煩。在設(shè)計(jì)時(shí)候jsp只負(fù)責(zé)顯示頁面,也就是說jsp調(diào)用Bean(Struts,servlet)傳過來的數(shù)據(jù)然后顯示而Bean(Struts,servlet)負(fù)責(zé)收集jsp需要的數(shù)據(jù),用ArrayList(Arttibute)傳給jsp。假如需要提交表單,一般也直接提交給Struts,servlet,處理后以后再返回處理信息。而其中相應(yīng)的業(yè)務(wù)邏輯由Bean去實(shí)現(xiàn)。
四:Bean的設(shè)計(jì)
在我使用時(shí)候Bean通常有三類,分別在manager,entry,database目錄下面。
manager下面的bean做商業(yè)邏輯
entry下的bean就是封裝數(shù)據(jù),其實(shí)就是每個(gè)數(shù)據(jù)庫表對(duì)應(yīng)會(huì)有一個(gè)bean。jsp得到的也全部是類。
database下的bean就是操作數(shù)據(jù)庫,執(zhí)行如insert,update,delete,load(查詢一條記錄),batchload(查詢多條記錄)。
他們之間的關(guān)系是entry負(fù)責(zé)封裝數(shù)據(jù),作為database的調(diào)用參數(shù),返回結(jié)果。
manager調(diào)用database處理的結(jié)果。manager和jsp通信。jsp得到的結(jié)果從manager來, jsp需要做操作調(diào)用manager,即使是一個(gè)insert 在database存在這樣的方法但在manager中你還是需要再封裝一次。這樣做的目的是使結(jié)構(gòu)盡量簡單。database只負(fù)責(zé)操作數(shù)據(jù)庫。manager只做邏輯(取相應(yīng)的數(shù)據(jù))處理相應(yīng)的邏輯,而entry則只把database取到的數(shù)據(jù)封裝,或則把頁面得到的參數(shù)封裝,做為參數(shù)傳給相應(yīng)的Bean.
五:設(shè)計(jì)實(shí)例
下面我把留言板作為實(shí)例來討論:
entry/Guestbook.java(留言板對(duì)象)
database/GuestbookMap.java(更新,刪除,修改留言板)
manager/GuestbookManager.java(處理所有的事務(wù))
數(shù)據(jù)表結(jié)構(gòu)(postgresql)
create sequence seq_guestbook increment 1 ; /**序列號(hào)生成器**/ create table guestbook( id int8 default nextval('seq_guestbook'), /**主鍵**/ title varchar(64),/**主題**/ body text,/**內(nèi)容**/ sayid int8,/**發(fā)言人**/ toid int8,/**接受人**/ saytime datetime default now(),/**留言時(shí)間**/ 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 記錄結(jié)束 // 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://取記錄條數(shù) } } GuestbookManager.java |
根據(jù)需要封裝需要的方法,這部分才是你要寫的
上面的方式entry,database的文件可以自動(dòng)生成,這個(gè)工具我已經(jīng)開發(fā)了,如果需要聯(lián)系我。你需要寫的就是GuestbookManager里面的方法,你也許會(huì)覺得工作量比你所有的操作都在jsp中大,但是這樣結(jié)構(gòu)非常清晰。你還需要的就是寫一個(gè)數(shù)據(jù)庫連接池,你所有的數(shù)據(jù)庫操作都從一個(gè)地方取,每一次都去連接數(shù)據(jù)庫開銷很大的。