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

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

MVC模式構建JavaWeb程序【有圖解有源碼,易理解易掌握】

2019-11-14 09:07:22
字體:
來源:轉載
供稿:網友

一、MVC設計模式基礎

1.第一層V,即View,是視圖層,通常情況下是jsp頁面或HTML頁面,JSP頁面中主要由JSTL標簽以及EL表達式來顯示Servlet傳來的數據,并且通過用戶操作來傳遞數據給控制層。

2.第二層C,即Controller,是控制層,基本上是Servlet程序,接收來自視圖層傳來的數據,發送給第三層業務邏輯層,讓其處理后,根據不同的數據,來控制視圖層的顯示,起到了數據與視圖之間的橋梁作用。

3.第三層M,即Model,是組件層,控制著業務邏輯,接收控制層傳來的數據,并與持久層(數據庫)交互,反饋給控制層,所有的業務邏輯代碼均在組件層內。

二、基于MVC設計模式開發javaWeb程序的圖解。

這是一個簡單的用Maven構建的JavaWeb程序,具有登錄注冊功能。下面是圖解。

三、源代碼

1.登錄頁面

<%@ page language="java" contentType="text/html; charset=UTF-8"    pageEncoding="UTF-8"%><!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"><html><head><meta http-equiv="Content-Type" content="text/html; charset=UTF-8"><title>登錄</title></head><body>	<h1>登錄</h1>	<form action="LoginController" method="POST">		<input type="text" name="username"/>		<input type="passWord" name="password"/>		<input type="submit" name="submit"/>	</form>	</body></html>

2.注冊頁面

<%@ page language="java" contentType="text/html; charset=UTF-8"    pageEncoding="UTF-8"%><!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"><html><head><meta http-equiv="Content-Type" content="text/html; charset=UTF-8"><title>注冊</title></head><body>	<h1>注冊</h1>	<form action="RegisterController" method="POST">		<input type="text" name="username"/>		<input type="password" name="password"/>		<input type="submit" name="submit"/>	</form></body></html>

3.登陸后的主頁面

<%@ page language="java" contentType="text/html; charset=UTF-8"    pageEncoding="UTF-8"%><!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"><html><head><meta http-equiv="Content-Type" content="text/html; charset=UTF-8"><title>主界面</title></head><body>	用戶名:${sessionScope.userInfo.username }</body></html>

4.控制登錄的servlet

package servlet.controller;import java.io.IOException;import javax.servlet.ServletException;import javax.servlet.http.*;import dao.LoginHandler;import javabeans.UserInfo;public class LoginController extends HttpServlet {		@Override	PRotected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException{		doPost(request, response);	}	@Override	protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException{		response.setContentType("text/html");		UserInfo userInfo = new UserInfo();		userInfo.setUsername((String)request.getParameter("username"));		userInfo.setPassword((String)request.getParameter("password"));		LoginHandler handler = new LoginHandler();		if(handler.check(userInfo)){			HttpSession session = request.getSession(true);			session.setAttribute("userInfo", userInfo);			request.getRequestDispatcher("/WEB-INF/main.jsp").forward(request, response);		}else{			response.sendRedirect("login.jsp");		}	}}5.控制注冊的servlet

package servlet.controller;import java.io.IOException;import javax.servlet.ServletException;import javax.servlet.http.*;import dao.RegisterHandler;import javabeans.UserInfo;public class RegisterController extends HttpServlet {	@Override	protected void doGet(HttpServletRequest request, HttpServletResponse response) throws IOException, ServletException{		doPost(request, response);	}	@Override	protected void doPost(HttpServletRequest request, HttpServletResponse response) throws IOException, ServletException{		response.setContentType("text/html");		UserInfo userInfo = new UserInfo();		userInfo.setUsername(request.getParameter("username"));		userInfo.setPassword(request.getParameter("password"));		RegisterHandler handler = new RegisterHandler();		if(handler.register(userInfo)){			response.sendRedirect(getServletConfig().getServletContext().getContextPath() + "/login.jsp");		}else{			response.sendRedirect(getServletConfig().getServletContext().getContextPath() + "/register.jsp");		}	}}6.登錄業務邏輯組件

package dao;import java.sql.*;import javabeans.UserInfo;import utils.DB;public class LoginHandler {		private boolean flag = false;	public boolean check(UserInfo userInfo){		DB db = new DB();		PreparedStatement pstmt = db.getPreparedStatement("SELECT * FROM user_table WHERE username=?");		try {			pstmt.setString(1, userInfo.getUsername());			ResultSet rs = pstmt.executeQuery();			while(rs.next()){				System.out.println(rs.getString(2));				if(userInfo.getPassword().equals(rs.getString(2))){					flag = true;				}			}		} catch (SQLException e) {			e.printStackTrace();		}		return flag;	}}7.注冊業務邏輯組件

package dao;import java.sql.*;import javabeans.UserInfo;import utils.DB;public class RegisterHandler {		public boolean register(UserInfo userInfo){		DB db = new DB();		PreparedStatement pstmt = db.getPreparedStatement("SELECT * FROM user_table WHERE username=?");		try {			pstmt.setString(1, userInfo.getUsername());			ResultSet rs = pstmt.executeQuery();			if(rs.next()){				return false;			}			pstmt = db.getPreparedStatement("INSERT INTO user_table VALUES(?,?)");			pstmt.setString(1, userInfo.getUsername());			pstmt.setString(2, userInfo.getPassword());			pstmt.execute();			return true;		} catch (SQLException e) {			e.printStackTrace();			return false;		}	}}8.數據庫操作組件
package utils;import java.sql.*;import java.util.logging.Logger;public class DB{	private Connection connection = null;	private ResultSet resultSet = null;	private Statement statement = null;	private String dbName = "db";	private String username = "root";	private String password = "admin";	private String url = "jdbc:MySQL://localhost:3306/" + dbName;	private Logger logger = Logger.getLogger(this.getClass().getName());	public DB(){};	public Connection connect()	{		try		{			//加載驅動			Class.forName("com.mysql.jdbc.Driver");			//此時MySQL的Driver已經加入到DriverManager中,然后連接數據庫			connection = DriverManager.getConnection(url, username, password);		}		catch(Exception e)		{			logger.fine("連接失敗");;			e.printStackTrace();		}		return connection;	}	//獲得Statement類的對象,可以用此對象的方法執行sql語句	public Statement getStatement()	{		this.connect();		logger.info("con" + connection.toString());		try		{				statement = connection.createStatement();		}catch (Exception e)		{			logger.info("獲取statement失敗");			e.printStackTrace();		}				return statement;	}	public PreparedStatement getPreparedStatement(String sql){		this.connect();		PreparedStatement pstmt = null; 		try {			pstmt = connection.prepareStatement(sql);		} catch (SQLException e) {			logger.info("獲取preparedstatement失敗");		}		return pstmt;	}	//查詢	public ResultSet query(String sql)	{		this.getStatement();		logger.info("sta" + statement.toString());		try		{			resultSet = statement.executeQuery(sql);		}		catch (Exception e) 		{			logger.info("獲取結果集失敗");			e.printStackTrace();		}		logger.info("res" + resultSet);		return resultSet;	}	//更新數據庫	public int update(String sql)	{		int i = -1;		this.getStatement();		try		{			i = statement.executeUpdate(sql);			logger.info("插入后i=" + i);		}		catch(Exception e)		{			logger.info("更新失敗");			e.printStackTrace();		}		return i;	}}

如有任何問題,可以私信我。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲精品福利资源站| 久久69精品久久久久久国产越南| 国产精品igao视频| 久久国产精品久久久| 中文字幕日韩在线播放| 亚洲成人动漫在线播放| 色偷偷噜噜噜亚洲男人的天堂| 国产精品视频白浆免费视频| 国产精品三级久久久久久电影| 国产精品极品美女在线观看免费| 九九久久综合网站| 深夜成人在线观看| 中文字幕日韩综合av| 日韩在线精品一区| 丝袜美腿亚洲一区二区| 久久精品亚洲国产| 久久亚洲欧美日韩精品专区| 中文字幕久久亚洲| 91精品国产777在线观看| 亚洲成人久久久久| 精品视频9999| 日本老师69xxx| 美女少妇精品视频| 久久久人成影片一区二区三区| 欧美成人免费va影院高清| 精品久久久免费| 欧美性猛交xxxxx免费看| 三级精品视频久久久久| 日韩av手机在线看| 亚洲精品videossex少妇| 国产久一一精品| 国产在线精品成人一区二区三区| 色哟哟网站入口亚洲精品| 精品久久久久久中文字幕大豆网| 精品国产乱码久久久久久天美| xvideos成人免费中文版| 国产成人综合精品在线| 色哟哟入口国产精品| 一本色道久久88综合亚洲精品ⅰ| 国产97在线|日韩| 69久久夜色精品国产69乱青草| 韩剧1988免费观看全集| 国产精品吹潮在线观看| 日韩欧美在线看| 亚洲人成网站999久久久综合| 国产精品aaaa| 亚洲亚裔videos黑人hd| 亚洲精品456在线播放狼人| 疯狂蹂躏欧美一区二区精品| 中文字幕亚洲无线码a| 日韩av影片在线观看| 国模吧一区二区| 欧美激情亚洲国产| 中文字幕一区日韩电影| 国产有码一区二区| 成人a视频在线观看| 亚洲人成电影网站色| 国产精品视频色| 亚洲国产精品大全| 欧美多人乱p欧美4p久久| 91精品国产91久久久久福利| 精品国产网站地址| 97精品在线观看| 欧美性猛交xxxx偷拍洗澡| 日韩av在线播放资源| 精品性高朝久久久久久久| 日韩av在线导航| 最近2019中文字幕一页二页| 欧美超级乱淫片喷水| 亚洲国产成人久久综合| 美女久久久久久久| 成人免费网站在线看| 精品久久久中文| 久久久久国产精品免费网站| 精品国产乱码久久久久久虫虫漫画| 亚洲综合在线做性| 久久夜色撩人精品| 国产精品免费一区豆花| 成人在线国产精品| 日本久久久久久久久久久| 国产成人av网址| 亚洲三级黄色在线观看| 亚洲国产日韩欧美综合久久| 欧美日韩精品在线观看| 精品一区二区三区三区| 久久成人国产精品| 国产精品爱久久久久久久| 中文字幕免费精品一区| 色视频www在线播放国产成人| 国产精品三级美女白浆呻吟| 在线成人中文字幕| 精品久久中文字幕| 欧美在线视频一区| 欧美成人精品不卡视频在线观看| 欧美日韩国产中文精品字幕自在自线| 亲子乱一区二区三区电影| 色综合天天综合网国产成人网| 热re99久久精品国产66热| 夜夜嗨av一区二区三区免费区| 国产成人久久久精品一区| 欧美日韩国产第一页| 日韩大陆毛片av| 国产欧美精品日韩精品| 亚洲最大的网站| 日韩大胆人体377p| 久久亚洲电影天堂| 亚洲午夜国产成人av电影男同| 国产亚洲精品久久久| 亚洲第一福利网站| 欧美日产国产成人免费图片| 在线观看日韩www视频免费| 久久久久久国产精品美女| 欧美成人免费视频| www.色综合| 日韩精品欧美国产精品忘忧草| 在线一区二区日韩| 欧美激情视频播放| 欧美一级淫片丝袜脚交| 精品视频一区在线视频| 中文字幕日韩欧美在线视频| 精品久久久国产| 亚洲欧美日韩综合| 一区二区三区四区精品| 在线成人免费网站| 精品国产乱码久久久久久天美| 国产精品视频一区二区三区四| 成人a免费视频| 日韩中文在线中文网三级| xx视频.9999.com| 亚洲a级在线观看| 91久久精品在线| 久久99久久久久久久噜噜| 国产精品久久久一区| xvideos亚洲人网站| 日韩精品极品在线观看播放免费视频| 国产成人在线视频| 91久久久久久久久| 欧美精品aaa| 亚洲国产精品久久91精品| 欧美午夜片欧美片在线观看| 亚洲男人第一av网站| 欧美性20hd另类| 日韩av电影国产| 国产亚洲美女久久| 久久天天躁日日躁| 亚洲欧美国内爽妇网| 中文字幕国产日韩| 亚洲欧美视频在线| 91香蕉电影院| 岛国精品视频在线播放| 日韩电视剧免费观看网站| 欧美最猛性xxxxx(亚洲精品)| 国产97人人超碰caoprom| 97精品伊人久久久大香线蕉| 最新日韩中文字幕| 亚洲综合社区网| 日韩激情av在线播放| 亚洲欧美日韩视频一区| 影音先锋日韩有码| 亚洲免费av片| 久久久91精品国产一区不卡| 91国产中文字幕| 日韩电影免费在线观看| 91亚洲精品一区二区|