



免费预览已结束,剩余1页可下载查看
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
JDBC与JSP简单模拟MVC三层架构摘要:本文讲解了如何使用JSP简单模拟MVC三层架构并与JDBC连接。首先控制器接收用户的请求,并决定应该调用哪个模型来进行处理,然后模型用业务逻辑来处理用户的请求并返回数据,最后控制器用相应的视图格式化模型返回的数据,并通过表示层呈现给用户。 标签:MVC JSP JDBC 架构 链接 控制器 Oracle帮您准确洞察各个物流环节M是指数据模型,V是指用户界面,C则是控制器。使用MVC的目的是将M和V的实现代码分离,从而使同一个程序可以使用不同的表现形式。比如一批统计数据你可以分别用柱状图、饼图来表示。C存在的目的则是确保M和V的同步,一旦M改变,V应该同步更新。模型视图控制器(MVC)是Xerox PARC在八十年代为编程语言Smalltalk80发明的一种软件设计模式,至今已被广泛使用。最近几年被推荐为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();%trtd%=sform.getStudId() % /tdtd %=sform.getStudName() %/tdtd %=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 exceptionSystem.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(); 控制器控制器接受用户的输入并调用模型和视图
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 《共同债务分担与个人信用保护的离婚协议书》
- 离婚协议中车辆归属及权益划分明确约定合同
- 离婚协议书子女监护权与财产分割详细约定
- 劳动合同与聘用合同在人力资源管理中的实际操作比较
- 商业空间装修安全协议范本(施工环境防护)
- 旅游度假村租赁合同附加旅游服务协议
- 国际教育培训项目合同履行与师资力量保障
- 河北省张家口市2020-2021学年高一上学期名校联考(期中考试)考试历史试题
- 中考备考方法课件
- 芦花歌曲教学课件
- 2025年工会入职考试试题及答案
- 软件著作权无偿转让合同5篇
- 2025年公安警种知识测试题及答案
- 抵押车贷合同(标准版)
- 2025年秋季学期教科版三年级上册科学教学计划(三篇)
- 2024人教PEP版三年级英语上册全册教案
- 2025年秋季学期中小学开展工作重点观测指标一览表
- 农民公寓买卖合同协议书
- 燃气检修工模拟试题(附答案)
- 机械制图(第五版)全套课件
- 人卫慕课《走进肺功能》试题答案
评论
0/150
提交评论