Web 基础18 MVC与三层架构的入门(带案例)

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 思路分析

  小熊自己也是刚入门不久,这里只是我粗浅的思路,有兴趣的可以看看。

图解

mvc+三层架构.png
  1. 从整一个项目来说,贯穿项目的是数据,数据的传递,所以为了方便数据的传递,需要对数据进行封装,这里可以直接使用JavaBean进行封装。项目里面,会需要一个JavaBean类。
  2. 然后从网页开始,即表示层,在表示层我们会需要一个JSP来显示获取内容,还需要一个Servlet获取和封装数据
  3. 在业务逻辑层需要一个Service来处理业务逻辑。
  4. 最后需要一个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 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 findAll() throws SQLException {
        StudentDao dao = new StudentDao();//Dao层的数据传递与方法我们后面补上
        return dao.findAll();
    }
}


  • Dao的编写

JDBC 从数据拿取数据

public class StudentDao {
    public List findAll() throws SQLException {
        QueryRunner qr = new QueryRunner(JDBCUtils.getDataSource());
        return qr.query("select * from student", new BeanListHandler(Student.class));//List的形式封装
        
    }
}


工具类


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" %>




Insert title here


    
            
姓名 性别 年龄
${stu.sname} ${stu.gender} ${stu.age}

你可能感兴趣的:(Web 基础18 MVC与三层架构的入门(带案例))