Edzy_Java

  BlogJava :: 首页 ::  ::  ::  :: 管理 ::
  58 随笔 :: 12 文章 :: 11 评论 :: 0 Trackbacks

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流程。


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 查询
posted on 2006-11-15 18:11 lbfeng 阅读(319) 评论(0)  编辑  收藏 所属分类: Spring技术杂谈

只有注册用户登录后才能发表评论。


网站导航: