Robin's Blog

记录 积累 学习 成长

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::

就自己的理解与体会,谈谈Java中的MVC模式开发,希望对初学Java的朋友有点帮助. 



就目前而言,Java主要用于Web开发,即J2EE应用部分,说得难听点,从表面来看就是做 

网站,当然,这种网站不是简简点点由一些HTML堆成的. 

就我看来,目前在厦门招的Java程序员,主要也是从事MVC模式的开发居多. 


以下以一个在线图书借阅系统为例. 

1. 问题出现 

如果是要开发一个在线图书借阅系统,比如说是集美大学图书馆的借阅系统,这个系统 

希望被做成B/S模式的,用户只要有浏览器就可以使用这个系统. 

那么,在开发语言方面,我们可以选择使用纯JSP来开发. 

OK. 如果你选用纯JSP来开发,那么对于一个图书查询功能来说,你可能会这样实现: 

在一个JSP页面中,比如叫BookSearch.jsp中,你放置了一个表单,用户在这个页面中 

填写图书查询关键字,并提交这个表单,这个表单提交到自身页面,即BookSearch.jsp 

进行处理.BookSearch.jsp会在初始化页面时进行判断,如果有接收到用户提交的查询 

关键字,则查询数据库,并把查询结果显示出来.如果没有,则只显示图书查询表单.即, 

整个完整的业务功能流程是: 

(提交查询请求)              (拦截请求) 
BookSearch.jsp <---->     BookSearch.jsp   
(显示查询结果)            (执行业务逻辑) 

如果你用这种方式完成了整个系统.那么,如果现在客户----集大图书馆希望除了B/S外, 

还有个客户端,即桌面应用程序Application, 你便会发现,只为了多一个Application客 

户端,你却基本上要重写这个系统.因为你之前写的那些jsp页面对于你写Application没 

有什么帮助,代码无法重用. 

2. 什么是MVC? 为什么要使用MVC? 

如果我们使用MVC模式来开发,那么,以上代码无法重用的问题便迎刃而解. 

M: Model,即模型,负责业务逻辑部分,含执行业务逻辑部分和业务对象部分,一般为普通 

   Java类或EJB 

V: View,即视图,负责呈现在用户面前的部分,一般为JSP页面. 

C: Controller,即控制器,负责整个流程的控制,一般为Servlet. 

MVC就是视图、控制器、模型相分离的一种开发模式。 

如果用MVC模式来实现图书查询功能,那便会是这样的: 

在一个JSP页面中用户提交图书查询请求,Servlet拦截这个请求,并转发到相应的Java类/ 

EJB进行图书信息查询. 执行完图书查询后,返回查询结果给Servlet. Servlet把查询结果 

传给JSP,JSP显示查询结果. 

即流程为: 

(提交查询请求)             (拦截请求/C)        (执行业务逻辑) 
BookSearch.jsp(V) <---->    Servlet(C)  <--->   普通Java类/EJB(M) 
(显示查询结果)             (转发到JSP) 

如果是基于以上MVC模式实现,那么,如果此时希望系统多一个Application的客户端, 

则只需要添加C和V部分即可,M部分可以代码重用,大大提高工作效率. 

除了代码重用外,MVC还可以让逻辑更加清晰,各个组件都在实现什么功能非常清楚---- 

V作视图,C作控制器,M执行业务逻辑,这样对开发效率也有非常大的提高.试想一下,如果 

是像以上的纯JSP实现方式那样,把MVC混合在一个.jsp中,那么调试维护都是很困难的. 

3. MVC模式的具体实现 

在具体的实现上,View一般为JSP页面,它包含提交请求的页面(图书查询页面)和业务逻 

辑执行结果的显示页面(查询结果页面).这两个页面,有时可以集合成一个页面.JSP页面 

提交业务逻辑执行请求给Servlet,Servlet从普通Java类/EJB取得返回结果并返回给JSP, 

组织返回结果显示给用户. JSP只负责显示信息,不处理业务逻辑. 

在JSP页面中,我们可以使用scriptlet,即嵌入在jsp页面中的java代码,控制组织显示界面 


但我认为这不是一个好的选择.因为,如果网页美工与Java程序员不是同一个人,而且美工 

不懂Java(虽然俺还没有真的见过这种情况,现在很多小公司都是前后台同一个人,即网页 

美工同时也是Java程序员),那么,面对在.jsp页面中的一大堆Java代码,美工人员会很头疼 


而且,假设前后台开发人员不分离,那么在一个页面中调试与维护一个嵌入大量代码的jsp 

页面也是很麻烦的, 比如.jsp中的 

<% 
    } 
%> 

多了,总让人看了头晕. 更好的选择是使用TabLib,如JSTL。 使用JSTL,可以把形如 

<% 
   if() { 
      .... 
   } 
%> 的scriptlet变成 

<c:if ****> 

之类的标签,这样对于jsp代码的阅读、调试与维护非常有利。如果在JSTL的基础上加上JS 
P2.0 

的表达式语言(Expression Language),则更进一步有利于写出清晰的JSP代码. 以下是一 
个 

JSTL+ EL的例子: 

    <c:if test="${!empty NotFoundMsg}"> 
        <c:out value="<BR><font color=red>${NotFoundMsg}</font><BR>" 
                                             escapeXml="false" default=""/> 
    </c:if> 
    (如果参数NotFoundMsg不为空,则显示参数NotFoundMsg的内容). 

以下提到的Struts中,有非常丰富的标签,那些标签基本上都覆盖了JSTL. 

另外,在jsp页面中嵌入大量的CSS和Javascript代码,我认为也不是一个好的选择,同样的, 

我认为分离和CSS和Javascript是更好的选择,分离出他们二者会让jsp代码各清晰,也各有 

利于CSS代码和Javascript代码的复用. 


Controller则一般为Servlet, Servlet拦截JSP提交的请求,并把请求转发到相应的Java 

类/EJB上进行执行业务逻辑, 然后把Java类返回的结果,传给JSP. 


Model一般为普通Java类/EJB,实现业务逻辑.这些普通Java类/EJB接收Servlet传过来的参 

数,并由此执行业务逻辑,并把结果返回给Servlet. 目前, 大部分的中小项目都不使用EJB 

了,EJB似乎越来越冷,甚至现在有一个口号叫: "J2EE without EJB",不过,以前EJB是J2EE 

的核心.与EJB越来越冷相对的,Hibernate等ORM框架正在越来越热. 


除了最原始的JSP+Servlet+Java类的实现外,现在还有很多的MVC框架,像Struts,WebWorks 

等.其中,在中国现在最流行的是Struts框架,现在已经有越来越多的公司用Struts来进行 

开发了. 




OK, 差不多聊到这. 一毕业了就没再接触Java了,以前学的也逐渐淡忘了, 写这些的时候, 

就发现很多东西已经记不得了. 

今天写这些的目的之一就是希望在以前学的被忘掉前,写出来,能给Java新手一点帮助,不 

至于以前学的东西现在白白浪费掉. 


上文有错误的地方,欢迎指正. 
posted on 2010-09-28 21:20  Robin99  阅读(8865)  评论(0编辑  收藏  举报