亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

程序開發:MVC設計模式與應用

2019-11-14 22:41:33
字體:
來源:轉載
供稿:網友
程序開發:MVC設計模式與應用

MVC全名是Model View Controller,是模型(model)-視圖(view)-控制器(controller)的縮寫,一種軟件設計典范,用一種業務邏輯、數據、界面顯示分離的方法組織代碼,將業務邏輯聚集到一個部件里面,在改進和個性化定制界面及用戶交互的同時,不需要重新編寫業務邏輯。MVC被獨特的發展起來用于映射傳統的輸入、處理和輸出功能在一個邏輯的圖形化用戶界面的結構中。

下面講解簡單的登錄操作:

程序流程圖:

在本程序中用戶輸入的登陸信息提交給Servlet進行接收,Servlet接收到請求內容后首先對其合法性進行檢驗(例如:輸入的內容是否為空或者長度是否滿足要求等),如果驗證失敗,則將錯誤信息傳遞給登陸頁顯示,如果數據合法,則調用DAO層完成數據庫的驗證,根據驗證的結構跳轉到“登陸成功”或登陸失敗的頁面,在本程序中,為了操作便捷,將登陸成功或失敗的顯示頁都統一設置成登陸頁。MVC登陸程序清單:

No.

頁面名稱

文件類型

描述

1

User

javaBean

用戶登陸的VO操作類

2

DatabaseConnection

JavaBean

負責數據庫的連接和關閉操作

3

IUserDAO

JavaBean

定義登陸操作的DAO接口

4

UserDAOImpl

JavaBean

DAO接口的真實實現類,完成具體的登陸驗證

5

UserDAOPRoxy

JavaBean

定義代理操作,負責數據庫的打開和關閉并且調用真實主題

6

DAOFactory

JavaBean

工廠類,取得DAO接口的實例

7

LoginServlet

Servlet

接收請求參數,進行參數驗證,調用DAO完成具體的登陸驗證,并根據DAO的驗證結果返回登陸信息

8

login.jsp

JSP

提供用戶輸入的表單、可以顯示用戶登陸成功或失敗的信息

用戶登陸表結構:

JSP的功能

通過本道MVC程序,讀者可以清楚的感覺到,與最初的JSP開發(例如:JSP + JDBC或者是JSP + DAO)相比,現在的JSP頁面中的代碼已經減少了很多,只是簡單的完成了輸出,實際上在開發中,讀者一定要記住JSP中最好只包含以下三種類型的代碼:接收屬性:接收從Servlet傳遞過來的屬性;判斷語句:判斷傳遞到JSP中的屬性是否存在;輸出內容:使用迭代或者是VO進行輸出。一定要記住一點,在JSP頁面中唯一允許導入的包只能是java.util包,只要能把握住這一點,就可以開發出一個簡潔、清晰的JSP頁面。理解了以上信息下面開始操作源代碼
 User.java文件
package com.mvc.oumyye.vo ;/** *  * @author 偶my耶 *    實體類 */public class User {    private String userid ;    private String name ;    private String passWord ;    public void setUserid(String userid){        this.userid = userid ;    }    public void setName(String name){        this.name = name ;    }    public void setPassword(String password){        this.password = password ;    }    public String getUserid(){        return this.userid ;    }    public String getName(){        return this.name ;    }    public String getPassword(){        return this.password ;    }}
DatabaseConnection.java
package com.mvc.oumyye.dbc ;import java.sql.* ;/** *  * @author 偶my耶 *    數據庫連接 */public class DatabaseConnection {    private static final String DBDRIVER = "org.gjt.mm.MySQL.Driver" ;     private static final String DBURL = "jdbc:mysql://localhost:3306/mytest" ;    private static final String DBUSER = "root" ;    private static final String DBPASSWORD = "root" ;    private Connection conn = null ;    public DatabaseConnection() throws Exception{        try{            Class.forName(DBDRIVER) ;            this.conn = DriverManager.getConnection(DBURL,DBUSER,DBPASSWORD) ;        }catch(Exception e){            throw e ;        }    }    public Connection getConnection(){        return this.conn ;    }    public void close() throws Exception{        if(this.conn != null){            try{                this.conn.close() ;            }catch(Exception e){                throw e ;            }        }    }}

package com.mvc.oumyye.dao ;import com.mvc.oumyye.vo.User;public interface IUserDAO {        public boolean findLogin(User user) throws Exception ;} 
package com.mvc.oumyye.dao.impl ;import com.mvc.oumyye.dao.*;import com.mvc.oumyye.vo.User;import java.sql.* ;/** *  * @author 偶my耶 *    Dao實現類 */public class UserDAOImpl implements IUserDAO {    private Connection conn = null ;    private PreparedStatement pstmt = null ;    public UserDAOImpl(Connection conn){        this.conn = conn ;    }    public boolean findLogin(User user) throws Exception{        boolean flag = false ;        String sql = "SELECT name FROM user WHERE userid=? AND password=?" ;        this.pstmt = this.conn.prepareStatement(sql) ;        this.pstmt.setString(1,user.getUserid()) ;        this.pstmt.setString(2,user.getPassword()) ;        ResultSet rs = this.pstmt.executeQuery() ;        if(rs.next()){            user.setName(rs.getString(1)) ;                flag = true ;        }        this.pstmt.close() ;        return flag ;    }} 
DAOFactory.java
package com.mvc.oumyye.factory ;import com.mvc.oumyye.dao.*;import com.mvc.oumyye.dao.proxy.*;/** *  * @author 偶my耶 *    工廠接口 */public class DAOFactory {    public static IUserDAO getIUserDAOInstance(){        return new UserDAOProxy() ;    }}

UserDAOProxy.java
package com.mvc.oumyye.dao.proxy ;import com.mvc.oumyye.dbc.DatabaseConnection;import com.mvc.oumyye.dao.IUserDAO;import com.mvc.oumyye.dao.impl.UserDAOImpl;import com.mvc.oumyye.vo.User;/** *  * @author 偶my耶 *    工廠類 實現業務操作 */public class UserDAOProxy implements IUserDAO {    private DatabaseConnection dbc = null ;    private IUserDAO dao = null ;    public UserDAOProxy(){        try{            this.dbc = new DatabaseConnection() ;        }catch(Exception e){            e.printStackTrace() ;        }        this.dao = new UserDAOImpl(dbc.getConnection()) ;    }    public boolean findLogin(User user) throws Exception{        boolean flag = false ;        try{            flag = this.dao.findLogin(user) ;            }catch(Exception e){            throw e ;        }finally{            this.dbc.close() ;        }        return flag ;    }} 
LoginServlet.java
package com.mvc.oumyye.servlet ;import java.io.* ;import java.util.* ;import javax.servlet.* ;import javax.servlet.http.* ;import com.mvc.oumyye.factory.DAOFactory;import com.mvc.oumyye.vo.User;/** *  * @author 偶my耶 *    Servlet */public class LoginServlet extends HttpServlet {        private static final long serialVersionUID = 1L;    public void doGet(HttpServletRequest req,HttpServletResponse resp) throws ServletException,IOException{        String path = "login.jsp" ;        String userid = req.getParameter("userid") ;        String userpass = req.getParameter("userpass") ;        System.out.println(userid);        System.out.println(userpass);        List<String> info = new ArrayList<String>() ;            if(userid==null || "".equals(userid)){            info.add("用戶名不能為空!??!") ;        }        if(userpass==null || "".equals(userpass)){            info.add("密碼不能為空?。?) ;        }        if(info.size()==0){                User user = new User() ;            user.setUserid(userid) ;            user.setPassword(userpass) ;            try{                if(DAOFactory.getIUserDAOInstance().findLogin(user)){                    info.add("歡迎" + user.getName() + "登陸") ;                } else {                    info.add("請重新登錄") ;                }            }catch(Exception e){                e.printStackTrace() ;            }        }        req.setAttribute("info",info) ;        req.getRequestDispatcher(path).forward(req,resp) ;    }    public void doPost(HttpServletRequest req,HttpServletResponse resp) throws ServletException,IOException{        this.doGet(req,resp) ;    }}

web.xml文件

<?xml version="1.0" encoding="ISO-8859-1"?><web-app xmlns="http://java.sun.com/xml/ns/javaee"   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"   xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"   version="2.5">  <display-name>Welcome to Tomcat</display-name>  <description>     Welcome to Tomcat  </description>    <servlet>        <servlet-name>login</servlet-name>        <servlet-class>            com.mvc.oumyye.servlet.LoginServlet        </servlet-class>    </servlet>    <servlet-mapping>        <servlet-name>login</servlet-name>        <url-pattern>/LoginServlet</url-pattern>    </servlet-mapping></web-app>

login.jsp文件

<%@ page contentType="text/html" pageEncoding="GBK"%><%@ page import="java.util.*"%><html><head><title></title></head><body><script language="Javascript">    function validate(f){        if(!(/^/w{5,15}$/.test(f.userid.value))){            alert("用戶ID必須是5~15位!") ;            f.userid.focus() ;            return false ;        }        if(!(/^/w{5,15}$/.test(f.userpass.value))){            alert("密碼必須是5~15位!") ;            f.userpass.focus() ;            return false ;        }    }</script><%    request.setCharacterEncoding("GBK") ;%><%    List<String> info = (List<String>) request.getAttribute("info") ;    if(info != null){    // 有信息返回        Iterator<String> iter = info.iterator() ;        while(iter.hasNext()){%>            <h4><%=iter.next()%></h4><%        }    }%><form action="LoginServlet" method="post" onSubmit="return validate(this)">    用戶ID:<input type="text" name="userid"><br>    密&nbsp;&nbsp;碼:<input type="password" name="userpass"><br>    <input type="submit" value="登陸">    <input type="reset" value="重置"></form></body></html>

數據庫文件.sql

/*======================= 創建user數據表 =======================*/CREATE TABLE user(    userid            VARCHAR(30)        PRIMARY KEY ,    name            VARCHAR(30)        NOT NULL ,    password        VARCHAR(32)        NOT NULL) ;/*======================= 插入測試數據 =======================*/INSERT INTO user (userid,name,password) VALUES ('admin','administrator','admin') ;

效果圖:

MVC設計模式的好處:

JSP只負責顯示DAO負責數據層操作Servlet連接JSP和DAO,并根據JavaBean的操作結果進行跳轉
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲国产精品va在线看黑人| www欧美xxxx| 亚洲图片欧美午夜| 九九热精品视频在线播放| 伊人激情综合网| 亚洲免费中文字幕| 日韩中文在线不卡| 俺去啦;欧美日韩| 日韩欧美中文字幕在线观看| 精品亚洲一区二区三区四区五区| 欧美日韩国产123| 日韩小视频在线| 69精品小视频| 欧美日韩亚洲国产一区| 最近免费中文字幕视频2019| 国产精品一区久久| 成人写真福利网| 欧美激情在线有限公司| zzijzzij亚洲日本成熟少妇| 成人高h视频在线| 日韩精品在线免费观看视频| 在线国产精品视频| 久久精品久久久久久国产 免费| 亚洲xxxx做受欧美| 国产一区二区三区网站| 日韩专区在线观看| 欧美wwwxxxx| 97精品一区二区视频在线观看| 欧美日韩国产丝袜美女| 亚洲男子天堂网| 欧美性猛xxx| 国产精品日韩一区| 欧美成aaa人片在线观看蜜臀| 欧美成人sm免费视频| 亚洲男女自偷自拍图片另类| 久久成年人视频| 午夜精品99久久免费| 久久久久久有精品国产| 成人精品一区二区三区| 亚洲国产91色在线| 亚洲国产精品va在线观看黑人| 欧美综合一区第一页| 欧美一级成年大片在线观看| 7777精品视频| www.久久久久久.com| 日韩精品免费观看| 国产精品成人一区二区三区吃奶| 精品久久久久久久久久久久久久| 国产午夜精品免费一区二区三区| 91国在线精品国内播放| 国产欧美va欧美va香蕉在| 亚洲天堂av图片| 亚洲的天堂在线中文字幕| 亚洲人a成www在线影院| 亚洲第一区第一页| 成人免费在线视频网站| 成人av番号网| 91产国在线观看动作片喷水| 国产在线播放91| 日韩av一区二区在线观看| 一区二区福利视频| 日韩欧美黄色动漫| 国产精品免费福利| 国外成人免费在线播放| 国产精品久久久久77777| 免费av在线一区| 国产精品视频xxxx| 日韩av网址在线| 国产午夜精品全部视频在线播放| 亚洲最大成人免费视频| 午夜精品一区二区三区视频免费看| 欧美精品videos另类日本| 亚洲天堂av高清| 国产午夜精品理论片a级探花| 韩国福利视频一区| 日韩免费av一区二区| 在线播放精品一区二区三区| 欧美电影免费观看高清| 狠狠久久亚洲欧美专区| 久久精品国产2020观看福利| 正在播放国产一区| 日韩国产在线看| 日本精品一区二区三区在线| 国产成人一区二区在线| 日韩精品视频在线观看网址| 亚洲欧美国产制服动漫| 97视频免费在线看| 欧美福利视频在线| 欧美精品久久久久久久久久| 欧美在线视频在线播放完整版免费观看| 在线免费观看羞羞视频一区二区| 一区二区在线免费视频| 欧美在线视频网| 久久精品久久久久久| 不卡av电影在线观看| 大胆人体色综合| 性夜试看影院91社区| 成人免费视频a| www.欧美三级电影.com| 日韩av在线一区二区| 国产精品最新在线观看| 成人看片人aa| 在线视频一区二区| 日韩精品高清在线观看| 欧美精品在线观看91| 亚洲欧美日韩一区二区在线| 亚洲精品色婷婷福利天堂| 亚洲人午夜精品| 亚洲国产欧美在线成人app| 欧美性xxxx在线播放| 亚洲精品一区二区在线| 国产不卡av在线免费观看| 大桥未久av一区二区三区| 欧美做爰性生交视频| 欧美激情奇米色| 亚洲国产成人一区| 免费91麻豆精品国产自产在线观看| 日韩一区视频在线| 奇门遁甲1982国语版免费观看高清| 亚洲激情视频在线播放| 国产日韩精品一区二区| 亚洲福利在线看| 成人久久久久爱| 最好看的2019的中文字幕视频| 亚洲欧美国产日韩中文字幕| 国产精品夜间视频香蕉| 久久久久久久久久久免费| 日本精品在线视频| 久久香蕉国产线看观看av| 国产精品偷伦视频免费观看国产| 91国产视频在线| 韩国福利视频一区| 国产成人精品国内自产拍免费看| 国内精品久久久久久久久| 国内精品久久久久影院 日本资源| 国产精品久久久久久婷婷天堂| 性色av一区二区三区红粉影视| 亚洲成avwww人| 亚洲久久久久久久久久| 91日韩在线播放| 国产精品高清在线| 欧美大片在线免费观看| 2024亚洲男人天堂| 久久91精品国产91久久久| 国产精品免费一区二区三区都可以| 欧美日韩中文字幕在线| 成人网在线免费看| 亚洲欧美制服中文字幕| 日韩av有码在线| 青青a在线精品免费观看| 欧美日韩久久久久| 精品亚洲一区二区三区| 人人做人人澡人人爽欧美| 日韩精品免费在线观看| 永久免费毛片在线播放不卡| 国产精品高潮呻吟久久av无限| 欧美第一黄色网| 中文字幕精品久久| 精品福利视频导航| 美日韩在线视频| 亚洲国产精品系列| 日韩精品视频免费专区在线播放| 成人黄色免费网站在线观看| 欧美激情在线狂野欧美精品|