`
anson_xu
  • 浏览: 503005 次
  • 性别: Icon_minigender_1
  • 来自: 惠州
社区版块
存档分类

Spring MVC分析

阅读更多
Spring MVC
Author: 江南白衣

1.总体设计
      MVC框架如Struts、Webwork,都在Servlet的基础上创建了一个自己的绝对空间,在自己的空间里定义MVC世界和规则。无论这个世界定义得是否漂亮,程序员都有一个学习世界的过程。

      而Spring MVC则完全保留着Servlet概念中的request,response和session,并没有强制建立一个自己的概念模型(当然,他也有很烂的SimpleFormController,但你完全可以把它踢在一旁不管),也不强制需要FormBean和一堆XML定义。

      同时,它透明完成了与Spring的集成,Multi-action的派发,提供了绑定request数据用的binder等基本API。

      所以,如果想简单,使用Spring MVC的原始形态是一个很好的,类似于RoR中ActionPack的方案。

      推荐使用一个Controller响应一组相关动作的MultiActionController。同时,虽然一点不喜欢FormController定义的概念模型,但还是不影响发挥拿来主义,在共性比较明显后台管理模块,定义MultiActionFormController,自动完成某些共同的Form流程。

      你还是很喜欢WebWork?好在我们也提供了sample,见2.4 WebWork 。

2.写给在用其他MVC框架程序员的快速入门
      也许,所有程序员都先放下自己框架里的概念模型,还原回一个JSP/Servlet程序员的角度,思考一个JSP/Servlet框架需要的功能。

     0. 配置文件

         Spring的配置文件默认为WEB-INF/xxxx-servelet.xml。

         其中xxx为web.xml中org.springframework.web.servlet.DispatcherServlet的servlet-name。

     1. 与Spring集成及IOC

          天然兮,由DispatcherServlet完成。

      2. Action及Multi-Action 分发

          Spring将按照配置文件定义的URL,Mapping到具体Controller类,再根据URL里的action= xxx或其他参数,利用反射调用Controller里对应的Action方法。

      3. 输入数据绑定

          Spring提供Binder 通过名字的一一对应反射绑定Pojo,也可以直接从request.getParameter()取数据。

          如果没有另外加入框架封装,需要手工调用Binder.

      4. 输入数据验证

          Sping 提供了Validator接口,而Spring Module还整合了Commons-Validaor 。

      5. 结果数据放回View

          有个ModelAndView的概念,代表了返回的View名及数据(Model,一个Map)。可以用modelAndView.addObject()放入数据。当然,也可以直接request.setAttribute()。

      6. Interceptor

          AOP概念,其实Servlet里面早有Filter概念,不过Inteceptor可以更灵活的Mapping,另提供postHandle的插入点

          preHandle() handler开工之前。
          postHandle() hander开工之后,但DispatchServlet还没有渲染页面。
          afterCompletion() 一切完工之后。
       

      7. Redirect,Forward页面及Token防止重复提交。

          Spring提供 "redirect:index.jsp", "forward:index.jsp"这样的简写。

          Spring Simple Form提供了防止重复提交的机制。

      8. 如果想直接编写Response返回字符串, 而不是返回一个View

          将函数的返回类型设为void,使用ss封装的 rendText(response,String text)函数。

3.Spring MVC Multi-action
3.1 基本配置
   <bean id="methodNameResolver" class="org.springframework.web.servlet.mvc.multiaction.ParameterMethodNameResolver">        <property name="paramName">            <value>method</value>        </property>        <property name="defaultMethodName">            <value>index</value>     
      </property>
</bean>
以上配置将按xxx.do?method= list 将调用controller的list()方法

不过还要争取早日改为Web2.0式的写法./book/list.htm 要优于/book.do?action= list。

其余配置和其他Spring MVC配置差不多,请看bookstore-servlet.xml,留意下面几个关键节点
<bean id="exceptionResolver">
<bean id="methodNameResolver">
<bean id="viewResolver">
<bean id="urlMapping">(留意最新的urlMapping简写语法.)

4.SpringSide BaseController
   继承于Spring的MultiActionController, 对其作了少量扩展--主要是对数据绑定的扩展,还加了一个SaveMessage函数。

   1.对数据绑定的扩展:

   a.InitBinder() 初始化Binder,注册日期类并允许数字类为空。

   b.对Bind and Validate函数的再包装
   本来Spring已有bind函数完成bind and validate, 但这个函数一来没有使用BindException作返回值而是抛出一个ServletException只好自己另外实现一个bindObject()函数。

   c.另外稍稍扩展了一些函数使其更好用。

2.SaveMessage():

如果是redirect的关系,message信息放在request.attribute()就会丢失,SaveMessage()将其放在session。
配合messageFilter,在渲染页面前,把它从session又移回request。


5.后台管理通用的BaseManageController
  Spring MVC中的SimpleFormController中的交互机制有值得参考的部分,但其只有一个onSubmit函数不能很好的表达CRUD的语义,所以将两者结合成Multi-ActionFormController是比较好的方法。通过约定命名,在基类实现list(),create()等函数和默认流程,而在子类实现onList(),onCreate()函数。

   目前只是初步结合两者,还有很大的改进空间。

   参考了RoR中的命名。BaseManageController即按照此命名定义基类。

list 显示对象列表的页面
create新增对象的输入界面
edit 修改对象的输入界面
show 只读显示对象detai的页面
save 新增对象的保存
update 修改对象的保存
remove 删除单个对象
removeAll 批量删除对象
query 查询
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics