MVC

为何需要MVC?

  最早期的javaweb开发:Servlet==java+"html",问题:在Servlet中拼接字符串太麻烦

  后来出现Jsp:==Html+Java在Html中嵌套java代码, 问题:页面和逻辑太过于混杂

  最终导致:MVC的诞生!

  MVC是一种架构型的模式,本身不引入新的功能,就是指导我们把web应用结构做好

  特点:与功能无关

  目标:实现逻辑与页面相分离

MVC模式:Model、View、Control 即:模型、视图、控制器

  1:模型:包含应用程序的    业务逻辑    和    业务数据

  2:视图:包含应用程序的输出形式,即:页面或界面

  3:控制器:负责协调模型和视图;

        根据用户请求来选择要调用哪个模型来处理业务

        以及最终哪个视图为用户做出应答!

  

  MVC中的模型和视图是分离的、解耦的,同一个模型可以对应多种不同的视图

  具体功能:

  Model:

  封装应用状态                    --------->数据封装

  响应状态查询                    ---------->获取数据

  暴露应用的功能                  ----------->逻辑层API

  View:

  提供HTML form用于用户请求 ------->人机交互

  请求模型的更新                   ------->触发事件

  产生HTML响应                    ------->展示数据

  Controller:

  接收并验证HTTP请求的数据    -------->收集数据并封装数据

  将用户数据与模型的更新相映射-------->调用逻辑层API

  选择用于响应的视图     --------->根据返回值选择下一个页面

 纯Jsp应用

      无MVC的时候,系统结构图如下:

  

   这种结构不太好,在jsp页面写的代码太多,尤其是控制代码,业务和逻辑

  太过混杂,因此需要引入一个中间层----控制器来专门处理控制代码

  标准的MVC组建关系图如下:

  

  

桌面级开发实现标准的MVC:

  应用观察者模式,可以实现标准的MVC

  示例Demo:有空再说!

web企业级开发无法实现标准的MVC:

  原因:标准的MVC中,View在客户端,Model在服务器;

     那就是:当服务器这边数据更新了,它通知客户端那边跑着的HTML自动刷新

     这是不可能的!

     HTML在不重新装载页面的情况下,是不可能刷新的!

web实现改进型MVC:

  在实际开发web应用的时候,大多数情况是不会按照标准MVC做的,事实上也很难做到

  通常我们都会把逻辑部分移动到逻辑层,Model只用来封装数据,即VO;View一般不直

  接和逻辑层交互。

  逻辑层的交互都由控制器做,VIew只和控制器交互!如图:

  

    更狠一点的!如图:

  

  基本实现方式:

    View:Jsp

    Controller:Servlet

    Model:JavaBean

   从控制器如何传递值到Jsp实现?

  如果把Jsp页面看作Servlet,那么就是从一个Servlet向另一个Servlet传递参数

  方法:request(线程安全)、session(非线程安全,但很少并发,除非恶心操作)、servletcontext(非线程安全)

  对象:  同一个request请求          同一个客户端(不区分servlet)                            所有servlet(不区分客户端,不区分servlet)                    

  注意:

       建议首选request。但是该方式下,如果跳转页面,由于是同一个request

   所以,跳转方式只能用

         this.request.getRequestDispather("/your servlet url").forward(request,response);

   另一个方式:respose.sendRedirect("/your servlet url");

posted @ 2015-07-06 22:28  大数据从业者FelixZh  阅读(273)  评论(0编辑  收藏  举报