JDBC与JSP简单模拟MVC三层架构

开发 后端
本文讲解了如何使用JSP简单模拟MVC三层架构并与JDBC连接。首先控制器接收用户的请求,并决定应该调用哪个模型来进行处理,然后模型用业务逻辑来处理用户的请求并返回数据,最后控制器用相应的视图格式化模型返回的数据,并通过表示层呈现给用户。

M是指数据模型,V是指用户界面,C则是控制器。使用MVC的目的是将M和V的实现代码分离,从而使同一个程序可以使用不同的表现形式。比如一批统计数据你可以分别用柱状图、饼图来表示。C存在的目的则是确保M和V的同步,一旦M改变,V应该同步更新。

模型-视图-控制器(MVC)是Xerox PARC在八十年代为编程语言Smalltalk-80发明的一种软件设计模式,至今已被广泛使用。最近几年被推荐为Sun公司J2EE平台的设计模式,并且受到越来越多的使用 ColdFusion 和 PHP 的开发者的欢迎。模型-视图-控制器模式是一个有用的工具箱,它有很多好处,但也有一些缺点。

MVC是一个设计模式,它强制性的使应用程序的输入、处理和输出分开。使用MVC应用程序被分成三个核心部件:模型、视图、控制器。它们各自处理自己的任务。

视图

视图是用户看到并与之交互的界面。对老式的Web应用程序来说,视图就是由HTML元素组成的界面,在新式的Web应用程序中,HTML依旧在视图中扮演着重要的角色.

如何处理应用程序的界面变得越来越有挑战性。MVC一个大的好处是它能为你的应用程序处理很多不同的视图。在视图中其实没有真正的处理发生,不管这些数据是联机存储的还是一个雇员列表,作为视图来讲,它只是作为一种输出数据并允许用户操纵的方式。

代码实现:

package com.accp;
  public class StudentForm {
  private int studId;
  private String studName;
  private String studAge;
  public int getStudId() {
  return studId;
  }
  public void setStudId(int studId) {
  this.studId = studId;
  }
  public String getStudName() {
  return studName;
  }
  public void setStudName(String studName) {
  this.studName = studName;
  }
  public String getStudAge() {
  return studAge;
  }
  public void setStudAge(String studAge) {
  this.studAge = studAge;
  }
  }

JSP:

﹤%
  SimpleDateFormat  sf = new SimpleDateFormat("yyyy年MM月dd日");
  String dateString  = sf.format(new Date());
  out.print(dateString);
  StudentModel smodel = new StudentModel();
  ArrayList list =  smodel.ListStudent(DbConnection.getConnection());
  Iterator it = list.iterator();
  StudentForm sform=null;
  while(it.hasNext()){
  sform = (StudentForm)it.next();
  %﹥
  ﹤tr﹥﹤td﹥﹤%=sform.getStudId() %﹥ ﹤/td﹥﹤td﹥ ﹤%=sform.getStudName() %﹥
﹤/td﹥﹤td﹥ ﹤%=sform.getStudAge() %﹥﹤/td﹥   ﹤/tr﹥   ﹤%   }%﹥

模型

模型表示企业数据和业务规则。在MVC的三个部件中,模型拥有最多的处理任务。例如它可能用象EJBs和ColdFusion Components这样的构件对象来处理数据库。被模型返回的数据是中立的,就是说模型与数据格式无关,这样一个模型能为多个视图提供数据。由于应用于模型的代码只需写一次就可以被多个视图重用,所以减少了代码的重复性。

package com.accp;
  import java.util.ArrayList;
  import java.sql.Connection;
  import java.sql.PreparedStatement;
  import java.sql.Statement;
  import java.sql.ResultSet;
  public class StudentModel {
  private final String SQL_LIST = "SELECT studId,studName,studAge FROM StudentInfo";
  private final String SQL_ADD = "INSERT INTO StudentInfo(studName,studAge) VALUES(?,?)";
  public ArrayList ListStudent(Connection conn) {
  ArrayList list = null;
  Statement stmt = null;
  ResultSet rs = null;
  try {
  list = new ArrayList();
  stmt = conn.createStatement();
  rs = stmt.executeQuery(SQL_LIST);
  while(rs.next()){
  StudentForm sf = new StudentForm();
  sf.setStudId(rs.getInt("studId"));
  sf.setStudName(rs.getString("studName"));
  sf.setStudAge(rs.getString("studAge"));
  list.add(sf);
  }
  } catch (Exception e) {
  // TODO: handle exception
  System.out.println("查询异常:"+e.toString());
  } finally {
  DbConnection.closeResultSet(rs);
  DbConnection.closeStatement(stmt);
  DbConnection.closeConnection(conn);
  }
  return list;
  }
  }

数据连接:

package com.accp;
  import java.sql.Connection;
  import java.sql.DriverManager;
  import java.sql.ResultSet;
  import java.sql.Statement;
  import java.sql.PreparedStatement;
  public class DbConnection {
  private static String DRIVER_CLASS = "com.microsoft.sqlserver.jdbc.SQLServerDriver";
  private static String DATABASE_URL = "jdbc:sqlserver://localhost:1433;databaseName=Student";
  private static String DATABASE_USER = "sa";
  private static String DATABASE_PASSWORD = "sasa";
  public static Connection getConnection (){
  Connection conn= null;
  try {
  Class.forName(DRIVER_CLASS);
  conn = DriverManager.getConnection(DATABASE_URL, DATABASE_USER,
  DATABASE_PASSWORD);
  System.out.println("SQL2005 连接成功!");
  } catch (Exception ex) {
  System.out.println("2111:" + ex.getMessage());
  }
  return conn;
  }
  public static void closeConnection (Connection conn){
  try {
  if (conn != null) {
  conn.close();
  }
  } catch (Exception e) {
  System.out.println(e.toString());
  }
  }
  public static void closeStatement (Statement stmt){
  try {
  if (stmt != null) {
  stmt.close();
  }
  } catch (Exception e) {
  System.out.println(e.toString());
  }
  }
  public static void closeResultSet (ResultSet rs){
  try {
  if (rs != null) {
  rs.close();
  }
  } catch (Exception e) {
  System.out.println(e.toString());
  }
  }
  }

控制器

控制器接受用户的输入并调用模型和视图去完成用户的需求。所以当单击Web页面中的超链接和发送HTML表单时,控制器本身不输出任何东西和做任何处理。它只是接收请求并决定调用哪个模型构件去处理请求,然后确定用哪个视图来显示模型处理返回的数据。

现在我们总结MVC的处理过程,首先控制器接收用户的请求,并决定应该调用哪个模型来进行处理,然后模型用业务逻辑来处理用户的请求并返回数据,最后控制器用相应的视图格式化模型返回的数据,并通过表示层呈现给用户。

【编辑推荐】

  1. JSP技术优缺点深入分析
  2. JSP中Action属性的功能浅析
  3. JSP最佳实践 使用JSTL来更新JSP页面
责任编辑:佚名 来源: 新浪博客
相关推荐

2012-02-07 10:40:13

MVCJava

2009-04-30 15:56:50

三层架构MVCMVP

2009-07-28 15:08:50

MVC三层架构实例

2009-04-30 09:15:25

三层结构MVC架构

2011-04-19 13:53:41

三层架构

2012-02-02 13:04:50

JavaSpring

2019-07-26 08:39:29

JavaWebMVC

2018-03-08 15:30:31

超融合架构传统三层架构

2013-01-09 11:00:20

架构开发三层架构.NET架构

2009-08-26 18:20:42

三层架构

2009-07-28 17:25:14

ASP.NET三层结构

2011-08-08 14:14:03

架构

2012-02-03 09:44:33

.NET

2009-12-28 16:27:46

2015-07-02 10:57:11

General框架架构开发

2018-10-31 14:32:53

数据中心网络架构

2009-09-23 17:29:54

三层框架

2010-01-04 09:15:19

三层交换技术

2009-05-06 09:40:04

LINQWEB开发构架

2014-02-12 10:07:07

三层交换原理
点赞
收藏

51CTO技术栈公众号