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() %﹥ |
模型
模型表示企业数据和业务规则。在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的处理过程,首先控制器接收用户的请求,并决定应该调用哪个模型来进行处理,然后模型用业务逻辑来处理用户的请求并返回数据,最后控制器用相应的视图格式化模型返回的数据,并通过表示层呈现给用户。
【编辑推荐】