小編給大家分享一下JSP設(shè)計(jì)模式怎么用,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
成都創(chuàng)新互聯(lián)公司堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都網(wǎng)站制作、成都網(wǎng)站設(shè)計(jì)、外貿(mào)營(yíng)銷(xiāo)網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿(mǎn)足客戶(hù)于互聯(lián)網(wǎng)時(shí)代的康樂(lè)網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
◆JSP設(shè)計(jì)模式介紹
記得初學(xué)JSP的時(shí)候,總喜歡把他和ASP,PHP去比較,也習(xí)慣于使用Asp的開(kāi)發(fā)模式去寫(xiě)JSP后來(lái)才發(fā)現(xiàn)這真是很傻的做法,其實(shí)JSP一出了來(lái)就已經(jīng)用MVC模式了。下面我就簡(jiǎn)要說(shuō)說(shuō)JSP設(shè)計(jì)使用MVC來(lái)設(shè)計(jì)。
◆JSP設(shè)計(jì)模式中MVC介紹
MVC其實(shí)是模、視圖、控制的縮寫(xiě),也就是說(shuō)在使用JSP時(shí),有相應(yīng)的文件去實(shí)現(xiàn)相應(yīng)的操作
通常JSP只負(fù)責(zé)view也就是只負(fù)責(zé)顯示頁(yè)面。業(yè)務(wù)邏輯等有bean(ejb)去實(shí)現(xiàn)。下面討論的是不使用ejb的情況下實(shí)現(xiàn)。如果使用ejb,ejb負(fù)責(zé)M.C通常會(huì)由servlet去實(shí)現(xiàn)?;蛘呤褂胹truts。
◆JSP設(shè)計(jì)模式的設(shè)計(jì)思路
當(dāng)你構(gòu)建一個(gè)Application時(shí)。你必須考慮界面的問(wèn)題,而界面修改是非常平常的。如果你在Jsp中實(shí)現(xiàn)所有的操作,一旦修改界面你麻煩大了。美工不懂JSP的,你必須自己去修改無(wú)數(shù)個(gè)文件,頭不要太大,而此時(shí)一般時(shí)間都很緊,使用MVC則可以減少你的一些麻煩。在設(shè)計(jì)時(shí)候Jsp只負(fù)責(zé)顯示頁(yè)面,也就是說(shuō)Jsp調(diào)用Bean(Struts,servlet)傳過(guò)來(lái)的數(shù)據(jù)然后顯示而B(niǎo)ean(Struts,servlet)負(fù)責(zé)收集JSP需要的數(shù)據(jù),用ArrayList(Arttibute)傳給JSP。假如需要提交表單,一般也直接提交給Struts,servlet,處理后以后再返回處理信息。而其中相應(yīng)的業(yè)務(wù)邏輯由Bean去實(shí)現(xiàn)。
◆JSP設(shè)計(jì)模式中Bean的設(shè)計(jì)
在我使用時(shí)候Bean通常有三類(lèi),分別在manager,entry,database目錄下面。
manager下面的bean做商業(yè)邏輯
entry下的bean就是封裝數(shù)據(jù),其實(shí)就是每個(gè)數(shù)據(jù)庫(kù)表對(duì)應(yīng)會(huì)有一個(gè)bean。Jsp得到的也全部是類(lèi)。
database下的bean就是操作數(shù)據(jù)庫(kù),執(zhí)行如insert,update,delete,load(查詢(xún)一條記錄),batchload(查詢(xún)多條記錄)。
他們之間的關(guān)系是entry負(fù)責(zé)封裝數(shù)據(jù),作為database的調(diào)用參數(shù),返回結(jié)果。
manager調(diào)用database處理的結(jié)果。manager和Jsp通信。JSP得到的結(jié)果從manager來(lái), JSP需要做操作調(diào)用manager,即使是一個(gè)insert 在database存在這樣的方法但在manager中你還是需要再封裝一次。這樣做的目的是使結(jié)構(gòu)盡量簡(jiǎn)單。database只負(fù)責(zé)操作數(shù)據(jù)庫(kù)。manager只做邏輯(取相應(yīng)的數(shù)據(jù))處理相應(yīng)的邏輯,而entry則只把database取到的數(shù)據(jù)封裝,或則把頁(yè)面得到的參數(shù)封裝,做為參數(shù)傳給相應(yīng)的Bean.
◆JSP設(shè)計(jì)模式的設(shè)計(jì)實(shí)例
下面我把留言板作為實(shí)例來(lái)討論:
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/**是否查看過(guò)**/ ); 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 查詢(xún)條件 file://orderstr 排序條件 file://rcdbegin 記錄開(kāi)始 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ù)需要封裝需要的方法,這部分才是你要寫(xiě)的
上面的方式entry,database的文件可以自動(dòng)生成。需要寫(xiě)的就是GuestbookManager里面的方法,你也許會(huì)覺(jué)得工作量比你所有的操作都在JSP中大,但是這樣結(jié)構(gòu)非常清晰。還需要的就是寫(xiě)一個(gè)數(shù)據(jù)庫(kù)連接池,所有的數(shù)據(jù)庫(kù)操作都從一個(gè)地方取,每一次都去連接數(shù)據(jù)庫(kù)開(kāi)銷(xiāo)很大的。
以上是“JSP設(shè)計(jì)模式怎么用”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!