1.1 MVC 模式简介
MVC全名是Model View Controller,是模型(model)-视图(view)-控制器(controller)的缩写,一种软件设计典范,用一种业务逻辑、数据、界面显示分离的方法组织代码,将业务逻辑聚集到一个部件里面,在改进和个性化定制界面及用户交互的同时,不需要重新编写业务逻辑。MVC被独特的发展起来用于映射传统的输入、处理和输出功能在一个逻辑的图形化用户界面的结构中。
- JSP + Servlet + JavaBean
- v ---JSP 显示数据
- C ---Servlet 获取数据,封装数据,传输数据(域对象),控制流程跳转,处理业务逻辑
- M ---JavaBean 增删改查
这里推荐一般书《大话设计模式》
这里说一下Java开发经过的三个阶段
- 开发3个阶段:
- 只有Servlet 没有jsp 痛苦
- 抛弃Servlet,只用jsp 在jsp里面 操作数据库 操作xml 还要处理国际化 可读性非常的差
- MVC+三层架构 各司其职 jsp擅长页面的输出 Servlet擅长逻辑判断 程序清晰
1.2 三层架构与MVC
这里要很认真的告诉你们MVC和三层架构是两个东西,一定要记住呀
摘自百度百科
三层架构(3-tier architecture) 通常意义上的三层架构就是将整个业务应用划分为:界面层(User Interface layer)、业务逻辑层(Business Logic Layer)、数据访问层(Data access layer)。区分层次的目的即为了“高内聚低耦合”的思想。在软件体系架构设计中,分层式结构是最常见,也是最重要的一种结构。微软推荐的分层式结构一般分为三层,从下至上分别为:数据访问层、业务逻辑层(又或称为领域层)、表示层。
-
表示层
- 客户端(浏览器)
- Servlet:获取数据,封装数据
- jsp: 显示数据
-
业务逻辑层
- service:处理业务逻辑
-
数据访问层
- dao:增删改查
- db:数据库
1.2.1 三层架构的优点
- 可以分工合作
- 每一个层依赖性比较低,可以实现解耦,分工明确,实现团队协作开发
- 代码的重用性很高
- Struts Hibernate Spring 3大框架 其实对应着这3层
- Struts 表示层框架也就是web层技术(处理乱码,封装数据,处理业务逻辑,实现页面跳转)
- Hibernate 数据持久化 对应着我们的dao 以前jdbc自己写 完全面向对象
- Spring 业务逻辑层 核心技术 IOC(依赖注入) AOP(面向切面编程) 核心思想 - 解耦 通过配置文件 在运行的时候把对象注入进去
1.3 案例
从数据库取得所有数据数据放到网页显示
这个案例只是帮助大家的理解,不是!不是!不是!项目开发用的。
1.3.1 思路分析
小熊自己也是刚入门不久,这里只是我粗浅的思路,有兴趣的可以看看。
图解
- 从整一个项目来说,贯穿项目的是数据,数据的传递,所以为了方便数据的传递,需要对数据进行封装,这里可以直接使用JavaBean进行封装。项目里面,会需要一个JavaBean类。
- 然后从网页开始,即表示层,在表示层我们会需要一个JSP来显示获取内容,还需要一个Servlet获取和封装数据
- 在业务逻辑层需要一个Service来处理业务逻辑。
- 最后需要一个Dao来对数据库曾删改查。
- 会使用MySQL的相关知识。
1.3.2 一起开始写程序吧!
- 环境搭建
- 主要是 JDBC的环境搭建与配置
- 特别是C3p0的配置文件
- 完成Java的编写
public class Student implements Serializable {
private Integer sid;
private String sname;
private String gender;
private int age;
public Student() {
super();
// TODO Auto-generated constructor stub
}
public Integer getSid() {
return sid;
}
public void setSid(Integer sid) {
this.sid = sid;
}
public String getSname() {
return sname;
}
public void setSname(String sname) {
this.sname = sname;
}
public String getGender() {
return gender;
}
public void setGender(String gender) {
this.gender = gender;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
}
- 这里我们先写Servlet 为什么呢其实是我觉的servlet的负责了数据的接受与转发
public class StudentServlet extends HttpServlet {
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//获取所有的学生数据
StudentService service = new StudentService();//这个是我们的Serivce,我们可以先写着,然后在去后面补全这个Service 以及包含的方法
List<Student> list = null;
try {
list = service.findAll();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
//保存在域对象当中
request.setAttribute("list", list);
request.getRequestDispatcher("/list.jsp").forward(request, response);
}
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
doGet(request, response);
}
}
- Service的编写
由于我们的Service里面什么逻辑都没有只有专递数据
public class StudentService {
public List<Student> findAll() throws SQLException {
StudentDao dao = new StudentDao();//Dao层的数据传递与方法我们后面补上
return dao.findAll();
}
}
- Dao的编写
JDBC 从数据拿取数据
public class StudentDao {
public List<Student> findAll() throws SQLException {
QueryRunner qr = new QueryRunner(JDBCUtils.getDataSource());
return qr.query("select * from student", new BeanListHandler<Student>(Student.class));//List<JavaBean>的形式封装
}
}
工具类
public class JDBCUtils {
// 创建一个连接池:但是这个连接池只需要创建一次即可。
private static final ComboPooledDataSource dataSource = new ComboPooledDataSource();
/**
* 获得连接的方法
* @throws SQLException
*/
public static Connection getConnection() throws SQLException{
return dataSource.getConnection();
}
/**
* 获得数据源:
*/
public static DataSource getDataSource(){
return dataSource;
}
}
- jsp的页面显示
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<!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>Insert title here</title>
</head>
<body>
<table border="1" width="500">
<tr>
<td>姓名</td>
<td>性别</td>
<td>年龄</td>
</tr>
<c:forEach items="${list}" var="stu">
<tr>
<td>${stu.sname}</td>
<td>${stu.gender}</td>
<td>${stu.age}</td>
</tr>
</c:forEach>
</table>
</body>
</html>