`

Spring3 MVC 深入核心研究

 
阅读更多


一、前言:
二、核心类与接口:
三、核心流程图
四、DispatcherServlet说明
五、双亲上下文的说明
六、springMVC-mvc.xml 配置文件片段讲解
七、如何访问到静态的文件,如jpg,js,css?
八、请求如何映射到具体的Action中的方法?
九、Spring中的拦截器:
十、如何使用拦截器?
十一、如何实现全局的异常处理?
十二、如何把全局异常记录到日志中?
十三、如何给spring3 MVC中的Action做JUnit单元测试?
十四、转发与重定向
十五、处理ajax请求
十六、关于写几个配置文件的说明
十七、如何取得Spring管理的bean
十八、多视图控制器
十九、 <mvc:annotation-driven /> 到底做了什么工作
二十、 本文中springMVC.xml配置文件是核心,这里给一个下载地址

一、前言:

大家好,Spring3 MVC是非常优秀的MVC框架,由其是在3.0版本发布后,现在有越来越多的团队选择了Spring3 MVC了。Spring3 MVC结构简单,应了那句话简单就是美,而且他强大不失灵活,性能也很优秀。

官方的下载网址是:http://www.springsource.org/download (本文使用是的Spring 3.0.5版本)

Struts2也是比较优秀的MVC构架,优点非常多比如良好的结构。但这里想说的是缺点,Struts2由于采用了值栈、OGNL表达式、struts2标签库等,会导致应用的性能下降。Struts2的多层拦截器、多实例action性能都很好。可以参考我写的一篇关于Spring MVC与Struts2与Servlet比较的文章http://elf8848.iteye.com/admin/blogs/698217

Spring3 MVC的优点:

1、Spring3 MVC的学习难度小于Struts2,Struts2用不上的多余功能太多。呵呵,当然这不是决定因素。

2、Spring3 MVC很容易就可以写出性能优秀的程序,Struts2要处处小心才可以写出性能优秀的程序(指MVC部分)

3、Spring3 MVC的灵活是你无法想像的,Spring的扩展性有口皆碑,Spring3 MVC当然也不会落后,不会因使用了MVC框架而感到有任何的限制。

Struts2的众多优点:略... (呵呵,是不是不公平?)

众多文章开篇时总要吹些牛,吸引一下读者的眼球,把读者的胃口调起来,这样大家才有兴趣接着往后看。本文也没能例外。不过保证你看了之后不会后悔定有收获。

转载请注明出处:本文地址:http://elf8848.iteye.com/blog/875830

二、核心类与接口:

先来了解一下,几个重要的接口与类。现在不知道他们是干什么的没关系,先混个脸熟,为以后认识他们打个基础。

DispatcherServlet -- 前置控制器

HandlerMapping接口 -- 处理请求的映射

HandlerMapping接口的实现类:

SimpleUrlHandlerMapping 通过配置文件,把一个URL映射到Controller

DefaultAnnotationHandlerMapping 通过注解,把一个URL映射到Controller类上

HandlerAdapter接口 -- 处理请求的映射

AnnotationMethodHandlerAdapter类,通过注解,把一个URL映射到Controller类的方法上

Controller接口 -- 控制器

由于我们使用了@Controller注解,添加了@Controller注解注解的类就可以担任控制器(Action)的职责,

所以我们并没有用到这个接口。

HandlerInterceptor 接口--拦截器

无图,我们自己实现这个接口,来完成拦截的器的工作。

ViewResolver接口的实现类

UrlBasedViewResolver类 通过配置文件,把一个视图名交给到一个View来处理

InternalResourceViewResolver类,比上面的类,加入了JSTL的支持

View接口

JstlView类

LocalResolver接口

HandlerExceptionResolver接口 --异常处理

SimpleMappingExceptionResolver实现类

ModelAndView类

无图。

三、核心流程图

本图是我个人画的,有不严谨的地方,大家对付看吧。总比没的看强。

转载请注明出处:本文地址:http://elf8848.iteye.com/blog/875830


四、DispatcherServlet说明

使用Spring MVC,配置DispatcherServlet是第一步。

DispatcherServlet是一个Servlet,所以可以配置多个DispatcherServlet。

DispatcherServlet是前置控制器,配置在web.xml文件中的。拦截匹配的请求,Servlet拦截匹配规则要自已定义,把拦截下来的请求,依据某某规则分发到目标Controller(我们写的Action)来处理。

“某某规则”:是根据你使用了哪个HandlerMapping接口的实现类的不同而不同。

先来看第一个例子:

Xml代码收藏代码
  1. <web-app>
  2. <servlet>
  3. <servlet-name>example</servlet-name>
  4. <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
  5. <load-on-startup>1</load-on-startup>
  6. </servlet>
  7. <servlet-mapping>
  8. <servlet-name>example</servlet-name>
  9. <url-pattern>*.form</url-pattern>
  10. </servlet-mapping>
  11. </web-app>

<load-on-startup>1</load-on-startup>是启动顺序,让这个Servlet随Servletp容器一起启动。

<url-pattern>*.form</url-pattern> 会拦截*.form结尾的请求。

<servlet-name>example</servlet-name>这个Servlet的名字是example,可以有多个DispatcherServlet,是通过名字来区分的。每一个DispatcherServlet有自己的WebApplicationContext上下文对象。同时保存的ServletContext中和Request对象中,关于key,以后说明。

在DispatcherServlet的初始化过程中,框架会在web应用的 WEB-INF文件夹下寻找名为[servlet-name]-servlet.xml 的配置文件,生成文件中定义的bean。

第二个例子:

Xml代码收藏代码
  1. <servlet>
  2. <servlet-name>springMVC</servlet-name>
  3. <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
  4. <init-param>
  5. <param-name>contextConfigLocation</param-name>
  6. <param-value>classpath*:/springMVC.xml</param-value>
  7. </init-param>
  8. <load-on-startup>1</load-on-startup>
  9. </servlet>
  10. <servlet-mapping>
  11. <servlet-name>springMVC</servlet-name>
  12. <url-pattern>/</url-pattern>
  13. </servlet-mapping>

指明了配置文件的文件名,不使用默认配置文件名,而使用springMVC.xml配置文件。

其中<param-value>**.xml</param-value> 这里可以使用多种写法
1、不写,使用默认值:/WEB-INF/<servlet-name>-servlet.xml
2、<param-value>/WEB-INF/classes/springMVC.xml</param-value>
3、<param-value>classpath*:springMVC-mvc.xml</param-value>
4、多个值用逗号分隔


Servlet拦截匹配规则可以自已定义,Servlet拦截哪种URL合适?

当映射为@RequestMapping("/user/add")时:
1、拦截*.do,例如:/user/add.do,弊端:所有的url都要以.do结尾。不会影响访问静态文件。
2、拦截/app/*,例如:/app/user/add,弊端:请求的url都要包含/app,@RequestMapping("/user/add")中不须要包含/app。
3、拦截/,例如:/user/add,弊端:对jpg,js,css静态文件的访问也被拦截不能正常显示。后面有解决办法。
4、拦截/*,可以走到Action中,但转发到jsp时再次被拦截,不能访问到jsp。

五、双亲上下文的说明

如果你使用了listener监听器来加载配置,一般在Struts+Spring+Hibernate的项目中都是使用listener监听器的。如下

Java代码收藏代码
  1. <listener>
  2. <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
  3. </listener>

Spring会创建一个全局的WebApplicationContext上下文,称为根上下文,保存在ServletContext中,key是WebApplicationContext.ROOT_WEB_APPLICATION_CONTEXT_ATTRIBUTE属性的值。可以使用工具类取出上下文:WebApplicationContextUtils.getWebApplicationContext(ServletContext);

DispatcherServlet是一个Servlet,可以同时配置多个,每个DispatcherServlet有一个自己的WebApplicationContext上下文,这个上下文继承了根上下文中所有东西。保存在ServletContext中,key是"org.springframework.web.servlet.FrameworkServlet.CONTEXT"+Servlet名称。当一个Request对象产生时,会把这个WebApplicationContext上下文保存在Request对象中,key是DispatcherServlet.class.getName() + ".CONTEXT"。可以使用工具类取出上下文:RequestContextUtils.getWebApplicationContext(request);

Spring中的 ApplicationContext实例可以被限制在不同的作用域(scope)中。
在web MVC框架中,每个 DispatcherServlet有它自己的WebApplicationContext ,这个context继承了根 WebApplicationContext 的所有bean定义。
这些继承的bean也可以在每个serlvet自己的所属的域中被覆盖(override),覆盖后的bean 可以被设置上只有这个servlet实例自己使用的属性。

总结:不使用listener监听器来加载spring的配置,改用DispatcherServlet来加载spring的配置,不要双亲上下文,只使用一个DispatcherServlet,事情就简单了,什么麻烦事儿也没有了。

六、springMVC-mvc.xml 配置文件片段讲解(未使用默认配置文件名)

Xml代码收藏代码
  1. <?xmlversion="1.0"encoding="UTF-8"?>
  2. <beans
  3. xmlns="http://www.springframework.org/schema/beans"
  4. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  5. xmlns:tx="http://www.springframework.org/schema/tx"
  6. xmlns:context="http://www.springframework.org/schema/context"
  7. xmlns:mvc="http://www.springframework.org/schema/mvc"
  8. xsi:schemaLocation="http://www.springframework.org/schema/beans
  9. http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
  10. http://www.springframework.org/schema/tx
  11. http://www.springframework.org/schema/tx/spring-tx-3.0.xsd
  12. http://www.springframework.org/schema/context
  13. http://www.springframework.org/schema/context/spring-context-3.0.xsd
  14. http://www.springframework.org/schema/mvc
  15. http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd">
  16. <!--自动扫描的包名-->
  17. <context:component-scanbase-package="com.app,com.core,JUnit4"></context:component-scan>
  18. <!--默认的注解映射的支持-->
  19. <mvc:annotation-driven/>
  20. <!--视图解释类-->
  21. <beanclass="org.springframework.web.servlet.view.InternalResourceViewResolver">
  22. <propertyname="prefix"value="/WEB-INF/jsp/"/>
  23. <propertyname="suffix"value=".jsp"/><!--可为空,方便实现自已的依据扩展名来选择视图解释类的逻辑-->
  24. <propertyname="viewClass"value="org.springframework.web.servlet.view.JstlView"/>
  25. </bean>
  26. <!--拦截器-->
  27. <mvc:interceptors>
  28. <beanclass="com.core.mvc.MyInteceptor"/>
  29. </mvc:interceptors>
  30. <!--对静态资源文件的访问方案一(二选一)-->
  31. <mvc:default-servlet-handler/>
  32. <!--对静态资源文件的访问方案二(二选一)-->
  33. <mvc:resourcesmapping="/images/**"location="/images/"cache-period="31556926"/>
  34. <mvc:resourcesmapping="/js/**"location="/js/"cache-period="31556926"/>
  35. <mvc:resourcesmapping="/css/**"location="/css/"cache-period="31556926"/>
  36. </beans>

<context:component-scan/> 扫描指定的包中的类上的注解,常用的注解有:

@Controller 声明Action组件
@Service 声明Service组件 @Service("myMovieLister")
@Repository 声明Dao组件
@Component 泛指组件, 当不好归类时.
@RequestMapping("/menu") 请求映射
@Resource 用于注入,( j2ee提供的 ) 默认按名称装配,@Resource(name="beanName")
@Autowired 用于注入,(srping提供的) 默认按类型装配
@Transactional( rollbackFor={Exception.class}) 事务管理
@ResponseBody
@Scope("prototype") 设定bean的作用域

<mvc:annotation-driven /> 是一种简写形式,完全可以手动配置替代这种简写形式,简写形式可以让初学都快速应用默认配置方案。<mvc:annotation-driven /> 会自动注册DefaultAnnotationHandlerMapping与AnnotationMethodHandlerAdapter 两个bean,是spring MVC为@Controllers分发请求所必须的。
并提供了:数据绑定支持,@NumberFormatannotation支持,@DateTimeFormat支持,@Valid支持,读写XML的支持(JAXB),读写JSON的支持(Jackson)。
后面,我们处理响应ajax请求时,就使用到了对json的支持。
后面,对action写JUnit单元测试时,要从spring IOC容器中取DefaultAnnotationHandlerMapping与AnnotationMethodHandlerAdapter 两个bean,来完成测试,取的时候要知道是<mvc:annotation-driven />这一句注册的这两个bean。

如何替换<mvc:annotation-driven />?他到底做了什么工作,请看,最后面的 十九节<mvc:annotation-driven />到底做了什么工作。

<mvc:interceptors/> 是一种简写形式。通过看前面的大图,知道,我们可以配置多个HandlerMapping。<mvc:interceptors/>会为每一个HandlerMapping,注入一个拦截器。其实我们也可以手动配置为每个HandlerMapping注入一个拦截器。

<mvc:default-servlet-handler/> 使用默认的Servlet来响应静态文件。

<mvc:resources mapping="/images/**" location="/images/" cache-period="31556926"/> 匹配URL /images/** 的URL被当做静态资源,由Spring读出到内存中再响应http。

转载请注明出处:本文地址:http://elf8848.iteye.com/blog/875830


七、如何访问到静态的文件,如jpg,js,css?


如何你的DispatcherServlet拦截 *.do这样的URL,就不存在访问不到静态资源的问题。如果你的DispatcherServlet拦截“/”,拦截了所有的请求,同时对*.js,*.jpg的访问也就被拦截了。

目的:可以正常访问静态文件,不要找不到静态文件报404。

方案一:激活Tomcat的defaultServlet来处理静态文件

Xml代码收藏代码
  1. <servlet-mapping>
  2. <servlet-name>default</servlet-name>
  3. <url-pattern>*.jpg</url-pattern>
  4. </servlet-mapping>
  5. <servlet-mapping>
  6. <servlet-name>default</servlet-name>
  7. <url-pattern>*.js</url-pattern>
  8. </servlet-mapping>
  9. <servlet-mapping>
  10. <servlet-name>default</servlet-name>
  11. <url-pattern>*.css</url-pattern>
  12. </servlet-mapping>
  13. 要配置多个,每种文件配置一个

要写在DispatcherServlet的前面, 让defaultServlet先拦截,这个就不会进入Spring了,我想性能是最好的吧。


Tomcat, Jetty, JBoss, and GlassFish 自带的默认Servlet的名字 -- "default"
Google App Engine
自带的默认Servlet的名字 -- "_ah_default"
Resin
自带的默认Servlet的名字 -- "resin-file"
WebLogic
自带的默认Servlet的名字 -- "FileServlet"
WebSphere
自带的默认Servlet的名字 -- "SimpleFileServlet"


方案二: 在spring3.0.4以后版本提供了mvc:resources
mvc:resources 的使用方法:

Xml代码收藏代码
  1. <!--对静态资源文件的访问-->
  2. <mvc:resourcesmapping="/images/**"location="/images/"/>


/images/**映射到ResourceHttpRequestHandler进行处理,location指定静态资源的位置.可以是web application根目录下、jar包里面,这样可以把静态资源压缩到jar包中。cache-period 可以使得静态资源进行web cache

如果出现下面的错误,可能是没有配置<mvc:annotation-driven />的原因。
报错WARNING: No mapping found for HTTP request with URI [/mvc/user/findUser/lisi/770] in DispatcherServlet with name 'springMVC'

使用<mvc:resources/>元素,把mapping的URI注册到SimpleUrlHandlerMapping的urlMap中,
key为mapping的URI pattern值,而value为ResourceHttpRequestHandler,
这样就巧妙的把对静态资源的访问由HandlerMapping转到ResourceHttpRequestHandler处理并返回,所以就支持classpath目录,jar包内静态资源的访问.
另外需要注意的一点是,不要对SimpleUrlHandlerMapping设置defaultHandler.因为对static uri的defaultHandler就是ResourceHttpRequestHandler,
否则无法处理static resources request.

方案三 ,使用<mvc:default-servlet-handler/>

Xml代码收藏代码
  1. <mvc:default-servlet-handler/>

会把"/**" url,注册到SimpleUrlHandlerMapping的urlMap中,把对静态资源的访问由HandlerMapping转到org.springframework.web.servlet.resource.DefaultServletHttpRequestHandler处理并返回.
DefaultServletHttpRequestHandler使用就是各个Servlet容器自己的默认Servlet.

补充说明:多个HandlerMapping的执行顺序问题:

DefaultAnnotationHandlerMapping的order属性值是:0

<mvc:resources/>自动注册的SimpleUrlHandlerMapping的order属性值是:2147483646

<mvc:default-servlet-handler/>自动注册的SimpleUrlHandlerMapping的order属性值是:2147483647

spring会先执行order值比较小的。当访问一个a.jpg图片文件时,先通过DefaultAnnotationHandlerMapping来找处理器,一定是找不到的,我们没有叫a.jpg的Action。再按order值升序找,由于最后一个SimpleUrlHandlerMapping是匹配"/**"的,所以一定会匹配上,再响应图片。

访问一个图片,还要走层层匹配。真不知性能如何?改天做一下压力测试,与Apache比一比。

最后再说明一下,如何你的DispatcherServlet拦截 *.do这样的URL后缀,就不存上述问题了。还是有后缀方便。


八、请求如何映射到具体的Action中的方法?
方案一:基于xml配置映射,可以利用SimpleUrlHandlerMapping、BeanNameUrlHandlerMapping进行Url映射和拦截请求。
配置方法略。

方案二:基于注解映射,可以使用DefaultAnnotationHandlerMapping。

Xml代码收藏代码
  1. <beanclass="org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping"></bean>

但前面我们配置了<mvc:annotation-driven />,他会自动注册这个bean,就不须要我们显示的注册这个bean了。

如何替换<mvc:annotation-driven />?他到底做了什么工作,请看,最后面的 十九节<mvc:annotation-driven />到底做了什么工作。



以上都可以注入interceptors,实现权限控制等前置工作。
我们使用第2种,基于注解来使用spring MVC

并在action类上使用:
@Controller
@RequestMapping("/user")



九、Spring中的拦截器:
Spring为我们提供了:
org.springframework.web.servlet.HandlerInterceptor接口,

org.springframework.web.servlet.handler.HandlerInterceptorAdapter适配器,
实现这个接口或继承此类,可以非常方便的实现自己的拦截器。

有以下三个方法:

Action之前执行:
public boolean preHandle(HttpServletRequest request,
HttpServletResponse response, Object handler);

生成视图之前执行
public void postHandle(HttpServletRequest request,
HttpServletResponse response, Object handler,
ModelAndView modelAndView);

最后执行,可用于释放资源
public void afterCompletion(HttpServletRequest request,
HttpServletResponse response, Object handler, Exception ex)


分别实现预处理、后处理(调用了Service并返回ModelAndView,但未进行页面渲染)、返回处理(已经渲染了页面)
在preHandle中,可以进行编码、安全控制等处理;
在postHandle中,有机会修改ModelAndView;
在afterCompletion中,可以根据ex是否为null判断是否发生了异常,进行日志记录。
参数中的Object handler是下一个拦截器。


十、如何使用拦截器?
自定义一个拦截器,要实现HandlerInterceptor接口:

Java代码收藏代码
  1. publicclassMyInteceptorimplementsHandlerInterceptor{
  2. 略。。。
  3. }

Spring MVC并没有总的拦截器,不能对所有的请求进行前后拦截。
Spring MVC的拦截器,是属于HandlerMapping级别的,可以有多个HandlerMapping ,每个HandlerMapping可以有自己的拦截器。
当一个请求按Order值从小到大,顺序执行HandlerMapping接口的实现类时,哪一个先有返回,那就可以结束了,后面的HandlerMapping就不走了,本道工序就完成了。就转到下一道工序了。
拦截器会在什么时候执行呢? 一个请求交给一个HandlerMapping时,这个HandlerMapping先找有没有处理器来处理这个请求,如何找到了,就执行拦截器,执行完拦截后,交给目标处理器。
如果没有找到处理器,那么这个拦截器就不会被执行。


在spring MVC的配置文件中配置有三种方法:


方案一,(近似)总拦截器,拦截所有url

Java代码收藏代码
  1. <mvc:interceptors>
  2. <beanclass="com.app.mvc.MyInteceptor"/>
  3. </mvc:interceptors>

为什么叫“近似”,前面说了,Spring没有总的拦截器。

<mvc:interceptors/>会为每一 个HandlerMapping,注入一个拦截器。总有一个HandlerMapping是可以找到处理器的,最多也只找到一个处理器,所以这个拦截器总会被执行的。起到了总拦截器的作用。


方案二,(近似)总拦截器,拦截匹配的URL。

Xml代码收藏代码
  1. <mvc:interceptors>
  2. <mvc:interceptor>
  3. <mvc:mappingpath="/user/*"/><!--/user/*-->
  4. <beanclass="com.mvc.MyInteceptor"></bean>
  5. </mvc:interceptor>
  6. </mvc:interceptors>

就是比方案一多了一个URL匹配。

方案三,HandlerMappint上的拦截器

Xml代码收藏代码
  1. <beanclass="org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping">
  2. <propertyname="interceptors">
  3. <list>
  4. <beanclass="com.mvc.MyInteceptor"></bean>
  5. </list>
  6. </property>
  7. </bean>

如果使用了<mvc:annotation-driven />,它会自动注册DefaultAnnotationHandlerMapping 与AnnotationMethodHandlerAdapter 这两个bean,所以就没有机会再给它注入interceptors属性,就无法指定拦截器。

当然我们可以通过人工配置上面的两个Bean,不使用<mvc:annotation-driven />,就可以给interceptors属性注入拦截器了。

其实我也不建议使用<mvc:annotation-driven />,而建议手动写详细的配置文件,来替代<mvc:annotation-driven />,这就控制力就强了。

如何替换<mvc:annotation-driven />?他到底做了什么工作,请看,最后面的 十九节<mvc:annotation-driven />到底做了什么工作。

十一、如何实现全局的异常处理?

在spring MVC的配置文件中:

Xml代码收藏代码
  1. <!--总错误处理-->
  2. <beanid="exceptionResolver"class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver">
  3. <propertyname="defaultErrorView">
  4. <value>/error/error</value>
  5. </property>
  6. <propertyname="defaultStatusCode">
  7. <value>500</value>
  8. </property>
  9. <propertyname="warnLogCategory">
  10. <value>org.springframework.web.servlet.handler.SimpleMappingExceptionResolver</value>
  11. </property>
  12. </bean>

这里主要的类是SimpleMappingExceptionResolver类,和他的父类AbstractHandlerExceptionResolver类。

具体可以配置哪些属性,我是通过查看源码知道的。

你也可以实现HandlerExceptionResolver接口,写一个自己的异常处理程序。spring的扩展性是很好的。

通过SimpleMappingExceptionResolver我们可以将不同的异常映射到不同的jsp页面(通过exceptionMappings属性的配置)。

同时我们也可以为所有的异常指定一个默认的异常提示页面(通过defaultErrorView属性的配置),如果所抛出的异常在exceptionMappings中没有对应的映射,则Spring将用此默认配置显示异常信息。

注意这里配置的异常显示界面均仅包括主文件名,至于文件路径和后缀已经在viewResolver中指定。如/error/error表示/error/error.jsp

显示错误的jsp页面:

Html代码收藏代码
  1. <%@pagelanguage="java"contentType="text/html;charset=GBK"
  2. pageEncoding="GBK"%>
  3. <%@pageimport="java.lang.Exception"%>
  4. <!DOCTYPEhtmlPUBLIC"-//W3C//DTDHTML4.01Transitional//EN""http://www.w3.org/TR/html4/loose.dtd">
  5. <html>
  6. <head>
  7. <metahttp-equiv="Content-Type"content="text/html;charset=GBK">
  8. <title>错误页面</title>
  9. </head>
  10. <body>
  11. <h1>出错了</h1>
  12. <%
  13. Exceptione=(Exception)request.getAttribute("exception");
  14. out.print(e.getMessage());
  15. %>
  16. </body>
  17. </html>

其中一句:request.getAttribute("exception"),key是exception,也是在SimpleMappingExceptionResolver类默认指定的,是可能通过配置文件修改这个值的,大家可以去看源码。

参考文章:

http://www.blogjava.net/wuxufeng8080/articles/191150.html

http://fangjunai.blog.163.com/blog/static/1124970520108102013839/

十二、如何把全局异常记录到日志中?

在前的配置中,其中有一个属性warnLogCategory,值是“SimpleMappingExceptionResolver类的全限定名”。我是在SimpleMappingExceptionResolver类父类AbstractHandlerExceptionResolver类中找到这个属性的。查看源码后得知:如果warnLogCategory不为空,spring就会使用apache的org.apache.commons.logging.Log日志工具,记录这个异常,级别是warn。

值:“org.springframework.web.servlet.handler.SimpleMappingExceptionResolver”,是“SimpleMappingExceptionResolver类的全限定名”。这个值不是随便写的。因为我在log4j的配置文件中还要加入log4j.logger.org.springframework.web.servlet.handler.SimpleMappingExceptionResolver=WARN,保证这个级别是warn的日志一定会被记录,即使log4j的根日志级别是ERROR。

十三、如何给spring3 MVC中的Action做JUnit单元测试?

使用了spring3 MVC后,给action做单元测试也很方便,我以前从来不给action写单元测试的,再在不同了,方便了,所以一定要写。

JUnitActionBase类是所有JUnit的测试类的父类

Java代码收藏代码
  1. packagetest;
  2. importjavax.servlet.http.HttpServletRequest;
  3. importjavax.servlet.http.HttpServletResponse;
  4. importorg.junit.BeforeClass;
  5. importorg.springframework.mock.web.MockServletContext;
  6. importorg.springframework.web.context.WebApplicationContext;
  7. importorg.springframework.web.context.support.XmlWebApplicationContext;
  8. importorg.springframework.web.servlet.HandlerAdapter;
  9. importorg.springframework.web.servlet.HandlerExecutionChain;
  10. importorg.springframework.web.servlet.HandlerMapping;
  11. importorg.springframework.web.servlet.ModelAndView;
  12. importorg.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter;
  13. importorg.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping;
  14. /**
  15. *说明:JUnit测试action时使用的基类
  16. *
  17. *@author赵磊
  18. *@version创建时间:2011-2-2下午10:27:03
  19. */
  20. publicclassJUnitActionBase{
  21. privatestaticHandlerMappinghandlerMapping;
  22. privatestaticHandlerAdapterhandlerAdapter;
  23. /**
  24. *读取spring3MVC配置文件
  25. */
  26. @BeforeClass
  27. publicstaticvoidsetUp(){
  28. if(handlerMapping==null){
  29. String[]configs={"file:src/springConfig/springMVC.xml"};
  30. XmlWebApplicationContextcontext=newXmlWebApplicationContext();
  31. context.setConfigLocations(configs);
  32. MockServletContextmsc=newMockServletContext();
  33. context.setServletContext(msc);context.refresh();
  34. msc.setAttribute(WebApplicationContext.ROOT_WEB_APPLICATION_CONTEXT_ATTRIBUTE,context);
  35. handlerMapping=(HandlerMapping)context
  36. .getBean(DefaultAnnotationHandlerMapping.class);
  37. handlerAdapter=(HandlerAdapter)context.getBean(context.getBeanNamesForType(AnnotationMethodHandlerAdapter.class)[0]);
  38. }
  39. }
  40. /**
  41. *执行request对象请求的action
  42. *
  43. *@paramrequest
  44. *@paramresponse
  45. *@return
  46. *@throwsException
  47. */
  48. publicModelAndViewexcuteAction(HttpServletRequestrequest,HttpServletResponseresponse)
  49. throwsException{
  50. HandlerExecutionChainchain=handlerMapping.getHandler(request);
  51. finalModelAndViewmodel=handlerAdapter.handle(request,response,
  52. chain.getHandler());
  53. returnmodel;
  54. }
  55. }

这是个JUnit测试类,我们可以new Request对象,来参与测试,太方便了。给request指定访问的URL,就可以请求目标Action了。

Java代码收藏代码
  1. packagetest.com.app.user;
  2. importorg.junit.Assert;
  3. importorg.junit.Test;
  4. importorg.springframework.mock.web.MockHttpServletRequest;
  5. importorg.springframework.mock.web.MockHttpServletResponse;
  6. importorg.springframework.web.servlet.ModelAndView;
  7. importtest.JUnitActionBase;
  8. /**
  9. *说明:测试OrderAction的例子
  10. *
  11. *@author赵磊
  12. *@version创建时间:2011-2-2下午10:26:55
  13. */
  14. publicclassTestOrderActionextendsJUnitActionBase{
  15. @Test
  16. publicvoidtestAdd()throwsException{
  17. MockHttpServletRequestrequest=newMockHttpServletRequest();
  18. MockHttpServletResponseresponse=newMockHttpServletResponse();
  19. request.setServletPath("/order/add");
  20. request.addParameter("id","1002");
  21. request.addParameter("date","2010-12-30");
  22. request.setMethod("POST");
  23. //执行URI对应的action
  24. finalModelAndViewmav=this.excuteAction(request,response);
  25. //Assertlogic
  26. Assert.assertEquals("order/add",mav.getViewName());
  27. Stringmsg=(String)request.getAttribute("msg");
  28. System.out.println(msg);
  29. }
  30. }

需要说明一下:由于当前最想版本的Spring(Test) 3.0.5还不支持@ContextConfiguration的注解式context file注入,所以还需要写个setUp处理下,否则类似于Tiles的加载过程会有错误,因为没有ServletContext。3.1的版本应该有更好的解决方案,参见:https://jira.springsource.org/browse/SPR-5243

参考 :http://www.iteye.com/topic/828513

十四、转发与重定向

可以通过redirect/forward:url方式转到另一个Action进行连续的处理。

可以通过redirect:url 防止表单重复提交

写法如下:

return "forward:/order/add";

return "redirect:/index.jsp";

十五、处理ajax请求

1、引入下面两个jar包,我用的是1.7.2,好像1.4.2版本以上都可以,下载地址:http://wiki.fasterxml.com/JacksonDownload

jackson-core-asl-1.7.2.jar

jackson-mapper-asl-1.7.2.jar

2、spring的配置文件中要有这一行,才能使用到spring内置支持的json转换。如果你手工把POJO转成json就可以不须要使用spring内置支持的json转换。

<mvc:annotation-driven />

3、使用@ResponseBody注解

Java代码收藏代码
  1. /**
  2. *ajax测试
  3. *http://127.0.0.1/mvc/order/ajax
  4. */
  5. @RequestMapping("/ajax")
  6. @ResponseBody
  7. publicObjectajax(HttpServletRequestrequest){
  8. List<String>list=newArrayList<String>();
  9. list.add("电视");
  10. nbsp;list.add("洗衣机");
  11. list.add("冰箱");
  12. list.add("电脑");
  13. list.add("汽车");
  14. list.add("空调");
  15. list.add("自行车");
  16. list.add("饮水机");
  17. list.add("热水器");
  18. returnlist;
  19. }

转载请注明出处:本文地址:http://elf8848.iteye.com/blog/875830

十六、关于写几个配置文件的说明

我看到有的人把配置文件写两份:
一个是原有的applicationContext.xml,这个文件从spring2.0-2.5时一直在使用。
别一个是新加的spring MVC的配置文件。
其实这两个文件是可以写成一个文件的,springMVC相关的配置,数据源,事务相关配置可以都写再一个配置文件中。
本例子中只使用了一个spring配置文件叫“springMVC.xml”。
就不要再多配置一个applicationContext.xml文件了。
web.xml文件中也不要再配置org.springframework.web.context.ContextLoaderListener的listener了。
写两个配置文件spring会扫描两次。

写两个配置文件还出现事务不好使的现象,是当把@Transactional写有Action层时出现的。
如果写两个配置文件,先执行springMVC.xml(xxx-servlet.xml),后执行applicationContext.xml。
先执行springMVC.xml(xxx-servlet.xml)时,由于数据源、事务都配置在applicationContext.xml中,还没有执行(未准备好), 所以导致了上面的问题。

十七、如何取得Spring管理的bean(请用第3种方法)
1、servlet方式加载时,
【web.xml】

Xml代码收藏代码
  1. <servlet>
  2. <servlet-name>springMVC</servlet-name>
  3. <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
  4. <init-param>
  5. <param-name>contextConfigLocation</param-name>
  6. <param-value>classpath*:/springMVC.xml</param-value>
  7. </init-param>
  8. <load-on-startup>1</load-on-startup>
  9. </servlet>

spring容器放在ServletContext中的key是org.springframework.web.servlet.FrameworkServlet.CONTEXT.springMVC
注意后面的springMVC,是你的servlet-name配置的值,注意适时修改。

Java代码收藏代码
  1. ServletContextsc=略
  2. WebApplicationContextattr=(WebApplicationContext)sc.getAttribute("org.springframework.web.servlet.FrameworkServlet.CONTEXT.springMVC");

2、listener方式加载时:
【web.xml】

Xml代码收藏代码
  1. <context-param>
  2. <param-name>contextConfigLocation</param-name>
  3. <param-value>/WEB-INF/applicationContext</param-value>
  4. </context-param>
  5. <listener>
  6. <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
  7. </listener>

【jsp/servlet】可以这样取得

Java代码收藏代码
  1. ServletContextcontext=getServletContext();
  2. WebApplicationContextapplicationContext=WebApplicationContextUtils.getWebApplicationContext(context);

3、通用的方法来了,神器啊,前的 1、2两种方法并不通用,可以抛弃了。
在配置文件中加入:

Xml代码收藏代码
  1. <!--用于持有ApplicationContext,可以使用SpringContextHolder.getBean('xxxx')的静态方法得到springbean对象-->
  2. <beanclass="com.xxxxx.SpringContextHolder"lazy-init="false"/>
Java代码收藏代码
  1. importorg.springframework.context.ApplicationContext;
  2. importorg.springframework.context.ApplicationContextAware;
  3. /**
  4. *以静态变量保存SpringApplicationContext,可在任何代码任何地方任何时候中取出ApplicaitonContext.
  5. *
  6. */
  7. publicclassSpringContextHolderimplementsApplicationContextAware{
  8. privatestaticApplicationContextapplicationContext;
  9. /**
  10. *实现ApplicationContextAware接口的context注入函数,将其存入静态变量.
  11. */
  12. publicvoidsetApplicationContext(ApplicationContextapplicationContext){
  13. SpringContextHolder.applicationContext=applicationContext;//NOSONAR
  14. }
  15. /**
  16. *取得存储在静态变量中的ApplicationContext.
  17. */
  18. publicstaticApplicationContextgetApplicationContext(){
  19. checkApplicationContext();
  20. returnapplicationContext;
  21. }
  22. /**
  23. *从静态变量ApplicationContext中取得Bean,自动转型为所赋值对象的类型.
  24. */
  25. @SuppressWarnings("unchecked")
  26. publicstatic<T>TgetBean(Stringname){
  27. checkApplicationContext();
  28. return(T)applicationContext.getBean(name);
  29. }
  30. /**
  31. *从静态变量ApplicationContext中取得Bean,自动转型为所赋值对象的类型.
  32. */
  33. @SuppressWarnings("unchecked")
  34. publicstatic<T>TgetBean(Class<T>clazz){
  35. checkApplicationContext();
  36. return(T)applicationContext.getBeansOfType(clazz);
  37. }
  38. /**
  39. *清除applicationContext静态变量.
  40. */
  41. publicstaticvoidcleanApplicationContext(){
  42. applicationContext=null;
  43. }
  44. privatestaticvoidcheckApplicationContext(){
  45. if(applicationContext==null){
  46. thrownewIllegalStateException("applicaitonContext未注入,请在applicationContext.xml中定义SpringContextHolder");
  47. }
  48. }
  49. }

十八、多视图控制器

当有jsp,flt (模板)等多种页面生成展示方式时,spring默认使用的是“视图解析器链”。 真是一个链,所以性能不好,spring会在“视图解析器链”中顺序的查找,直到找到对应的 “视图解析器” 。jsp视图解析器一定要写在最后面,因为一旦调用jsp,就向浏览器发出数据了,Spring就没有机会再尝试下一个了。

所以自己写一个"多视图解析器",依靠扩展名来区分,可一次准确的选中一个 视图解析器,提高性能(会有多少提高呢?没测试过).

下面的例子支持jsp,flt (模板)两种页面生成展示方式,你中以自己添加,支持更多。

Xml代码收藏代码
  1. <!--多视图处理器-->
  2. <beanclass="com.xxx.core.web.MixedViewResolver">
  3. <propertyname="resolvers">
  4. <map>
  5. <entrykey="jsp">
  6. <beanclass="org.springframework.web.servlet.view.InternalResourceViewResolver">
  7. <propertyname="prefix"value="/WEB-INF/jsp/"/>
  8. <propertyname="viewClass"value="org.springframework.web.servlet.view.JstlView"></property>
  9. </bean>
  10. </entry>
  11. <entrykey="ftl">
  12. <beanclass="org.springframework.web.servlet.view.freemarker.FreeMarkerViewResolver">
  13. <propertyname="cache"value="true"/>
  14. <propertyname="contentType"value="text/html;charset=UTF-8"></property>
  15. <!--宏命令的支持-->
  16. <propertyname="exposeSpringMacroHelpers"value="true"/>
  17. <propertyname="viewClass"value="org.springframework.web.servlet.view.freemarker.FreeMarkerView"/>
  18. <propertyname="requestContextAttribute"value="rc"></property>
  19. </bean>
  20. </entry>
  21. </map>
  22. </property>
  23. </bean>
  24. <!--freemarkerconfig-->
  25. <beanid="freeMarkerConfigurer"class="org.springframework.web.servlet.view.freemarker.FreeMarkerConfigurer">
  26. <propertyname="templateLoaderPath"value="/WEB-INF/ftl/"/>
  27. <propertyname="freemarkerSettings">
  28. <props>
  29. <propkey="template_update_delay">5</prop>
  30. <propkey="default_encoding">UTF-8</prop>
  31. <propkey="locale">zh_CN</prop>
  32. </props>
  33. </property>
  34. </bean>

Java代码收藏代码
  1. importjava.util.Locale;
  2. importjava.util.Map;
  3. importorg.springframework.web.servlet.View;
  4. importorg.springframework.web.servlet.ViewResolver;
  5. /**
  6. *说明:多视图处理器
  7. *
  8. *@author赵磊
  9. *@version创建时间:2011-8-19上午09:41:09
  10. */
  11. publicclassMixedViewResolverimplementsViewResolver{
  12. privateMap<String,ViewResolver>resolvers;
  13. publicvoidsetResolvers(Map<String,ViewResolver>resolvers){
  14. this.resolvers=resolvers;
  15. }
  16. publicViewresolveViewName(StringviewName,Localelocale)throwsException{
  17. intn=viewName.lastIndexOf(".");
  18. if(n!=-1){
  19. //取出扩展名
  20. Stringsuffix=viewName.substring(n+1);
  21. //取出对应的ViewResolver
  22. ViewResolverresolver=resolvers.get(suffix);
  23. if(resolver==null){
  24. thrownewRuntimeException("NoViewResolverfor"+suffix);
  25. }
  26. returnresolver.resolveViewName(viewName,locale);
  27. }else{
  28. ViewResolverresolver=resolvers.get("jsp");
  29. returnresolver.resolveViewName(viewName,locale);
  30. }
  31. }
  32. }

十九、<mvc:annotation-driven />到底做了什么工作

一句<mvc:annotation-driven />实际做了以下工作:(不包括添加自己定义的拦截器)

我们了解这些之后,对Spring3 MVC的控制力就更强大了,想改哪就改哪里。

Xml代码收藏代码
  1. <!--注解请求映射-->
  2. <beanclass="org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping">
  3. <propertyname="interceptors">
  4. <list>
  5. <refbean="logNDCInteceptor"/><!--日志拦截器,这是你自定义的拦截器-->
  6. <refbean="myRequestHelperInteceptor"/><!--RequestHelper拦截器,这是你自定义的拦截器-->
  7. <refbean="myPermissionsInteceptor"/><!--权限拦截器,这是你自定义的拦截器-->
  8. <refbean="myUserInfoInteceptor"/><!--用户信息拦截器,这是你自定义的拦截器-->
  9. </list>
  10. </property>
  11. </bean>
  12. <beanclass="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter">
  13. <propertyname="messageConverters">
  14. <list>
  15. <refbean="byteArray_hmc"/>
  16. <refbean="string_hmc"/>
  17. <refbean="resource_hmc"/>
  18. <refbean="source_hmc"/>
  19. <refbean="xmlAwareForm_hmc"/>
  20. <refbean="jaxb2RootElement_hmc"/>
  21. <refbean="jackson_hmc"/>
  22. </list>
  23. </property>
  24. </bean>
  25. <beanid="byteArray_hmc"class="org.springframework.http.converter.ByteArrayHttpMessageConverter"/><!--处理..-->
  26. <beanid="string_hmc"class="org.springframework.http.converter.StringHttpMessageConverter"/><!--处理..-->
  27. <beanid="resource_hmc"class="org.springframework.http.converter.ResourceHttpMessageConverter"/><!--处理..-->
  28. <beanid="source_hmc"class="org.springframework.http.converter.xml.SourceHttpMessageConverter"/><!--处理..-->
  29. <beanid="xmlAwareForm_hmc"class="org.springframework.http.converter.xml.XmlAwareFormHttpMessageConverter"/><!--处理..-->
  30. <beanid="jaxb2RootElement_hmc"class="org.springframework.http.converter.xml.Jaxb2RootElementHttpMessageConverter"/><!--处理..-->
  31. <beanid="jackson_hmc"class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverter"/><!--处理json-->

二十、 本文中springMVC.xml配置文件是核心,这里给一个下载地址

要在http://www.iteye.com/网站有注册帐号才能下载

http://dl.iteye.com/topics/download/f7c02d0b-7c8f-3124-aaea-9b66a620e550

分享到:
评论
55 楼elf8848前天
http://faheemsohail.com/2011/10/difference-between-loading-context-via-dispatcherservlet-and-contextloaderlistener/
bbaacbbaac 写道
关于双亲上下文那里有点问题啊
请参看
http://www.coderanch.com/t/516563/Spring/DispatcherServlet-vs-ContextLoaderListener

http://faheemsohail.com/2011/10/difference-between-loading-context-via-dispatcherservlet-and-contextloaderlistener/

谢谢
54 楼bbaacbbaac前天
关于双亲上下文那里有点问题啊
请参看
http://www.coderanch.com/t/516563/Spring/DispatcherServlet-vs-ContextLoaderListener

http://faheemsohail.com/2011/10/difference-between-loading-context-via-dispatcherservlet-and-contextloaderlistener/
53 楼elf88482012-05-30
lxl631 写道
楼主你能不能再写一篇文章介绍 视图啊?
<!-- 视图解释类 -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/jsp/"/>
<property name="suffix" value=".jsp"/>
</bean>
不太明白

以后会的, 现在太忙,公司事儿太多了,现在主要精力在做网络通信。
52 楼lxl6312012-05-30
唔系好人 写道
在方法中使用注解为什么会出现
No mapping found for HTTP request with URI [/SpringTest1/] in DispatcherServlet with name 'appServlet'


找不到appServlet这个controler,对着requestmapping找找对吗
51 楼lxl6312012-05-30
楼主你能不能再写一篇文章介绍 视图啊?
<!-- 视图解释类 -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/jsp/"/>
<property name="suffix" value=".jsp"/>
</bean>
不太明白
50 楼唔系好人2012-05-30
在方法中使用注解为什么会出现
No mapping found for HTTP request with URI [/SpringTest1/] in DispatcherServlet with name 'appServlet'
49 楼hoho8182012-05-29
感谢楼主分享
48 楼imlovinitz2012-05-25
强大。。。
47 楼elf88482012-05-25
dictator_昌 写道
hs798630734 写道
Xml代码收藏代码
  1. <servlet-mapping>
  2. <servlet-name>default</servlet-name>
  3. <url-pattern>*.jpg</url-pattern>
  4. </servlet-mapping>
  5. <servlet-mapping>
  6. <servlet-name>default</servlet-name>
  7. <url-pattern>*.js</url-pattern>
  8. </servlet-mapping>
  9. <servlet-mapping>
  10. <servlet-name>default</servlet-name>
  11. <url-pattern>*.css</url-pattern>
  12. </servlet-mapping>


这样写感觉不太好,我都放到一个文件夹下面,用下面这样怎么不行呢?
Xml代码收藏代码
  1. <servlet-mapping>
  2. <servlet-name>default</servlet-name>
  3. <url-pattern>/resources/*</url-pattern>
  4. </servlet-mapping>


求指导

我觉得既然是默认,它内部就默认了路径,你给加上路径了,可能是找不到了。

后缀还是很重要的, action的url加上.do一切都解决了。
46 楼elf88482012-05-25
cppmule 写道
在Action上做单元测试,是不是有点过于测试了。
在Service层或者是 Models 进行测试就可以了?

是,没必要测
45 楼dictator_昌2012-05-24
hs798630734 写道
Xml代码收藏代码
  1. <servlet-mapping>
  2. <servlet-name>default</servlet-name>
  3. <url-pattern>*.jpg</url-pattern>
  4. </servlet-mapping>
  5. <servlet-mapping>
  6. <servlet-name>default</servlet-name>
  7. <url-pattern>*.js</url-pattern>
  8. </servlet-mapping>
  9. <servlet-mapping>
  10. <servlet-name>default</servlet-name>
  11. <url-pattern>*.css</url-pattern>
  12. </servlet-mapping>


这样写感觉不太好,我都放到一个文件夹下面,用下面这样怎么不行呢?
Xml代码收藏代码
  1. <servlet-mapping>
  2. <servlet-name>default</servlet-name>
  3. <url-pattern>/resources/*</url-pattern>
  4. </servlet-mapping>


求指导

我觉得既然是默认,它内部就默认了路径,你给加上路径了,可能是找不到了。
44 楼cppmule2012-05-22
在Action上做单元测试,是不是有点过于测试了。
在Service层或者是 Models 进行测试就可以了?
43 楼chunguangblog2012-05-19
不错学习了,比较全面
42 楼DemILong2012-05-18
受益匪浅,这正是我想要的,之前的时候都是用SSH开发的,现在转了一家公司,需要用到spring mvc+hibernate。但是spring mvc这方面之前没接触过,现在很想去学习,希望楼主能提供一些学习的资料,或者指引怎么学习才能上手的快,谢谢。
41 楼DemILong2012-05-18
受益匪浅,这正是我想好的,之前的时候都是用SSH开发的,现在转了一家公司,需要用到spring mvc+hibernate。但是spring mvc这方面之前没接触过,现在很想去学习,希望楼主能提供一些学习的资料,或者指引怎么学习才能上手的快,谢谢。
40 楼yyys85177502012-05-17
牛人啊
39 楼yeohcooller2012-05-17
貌似很强大,学习中。
38 楼hs7986307342012-05-12
Xml代码收藏代码
  1. <servlet-mapping>
  2. <servlet-name>default</servlet-name>
  3. <url-pattern>*.jpg</url-pattern>
  4. </servlet-mapping>
  5. <servlet-mapping>
  6. <servlet-name>default</servlet-name>
  7. <url-pattern>*.js</url-pattern>
  8. </servlet-mapping>
  9. <servlet-mapping>
  10. <servlet-name>default</servlet-name>
  11. <url-pattern>*.css</url-pattern>
  12. </servlet-mapping>


这样写感觉不太好,我都放到一个文件夹下面,用下面这样怎么不行呢?
Xml代码收藏代码
  1. <servlet-mapping>
  2. <servlet-name>default</servlet-name>
  3. <url-pattern>/resources/*</url-pattern>
  4. </servlet-mapping>

分享到:
评论

相关推荐

    深入解析Spring+MVC与Web+Flow.pdf

    《深入解析Spring MVCgn Web Flow》来自Spring开发团队的权威之作前所未有地深入剖析Spring MVC技术内幕大量专家经验和技巧,全面提升你的Web开发境界 Spring MVC和Spring Web Flow是Spring平台上两个极为灵活而且...

    Spring MVC 教程 快速入门 深入分析

    Spring MVC 教程 快速入门 深入分析 目录 一、前言 二、spring mvc 核心类与接口 三、spring mvc 核心流程图 四、spring mvc DispatcherServlet说明 五、spring mvc 双亲上下文的说明 六、springMVC-mvc.xml 配置...

    Spring MVC framework 深入分析

    在当今的MVC framework里,似乎Webwork2...确实,Spring的MVC framework不算是整个Spring的核心部件,但它的威力却超过了很多人的想象。很多人包括xiecc认为Spring的MVC framework是非常优秀的,甚至比Webwork2更优秀。

    Spring_MVC_教程_快速入门_深入分析

    spring mvc 核心类与接口 spring mvc 核心流程图 spring mvc DispatcherServlet说明 spring mvc 双亲上下文的说明 springMVC-mvc.xml 配置文件片段讲解 ...如何给spring3 MVC中的Action做JUnit单元测试?

    全面掌握Spring MVC:从基础到高级的实践指南

    作为架构师和Java开发者,深入理解Spring MVC的原理和实践应用是非常重要的。本文通过分析Spring MVC的核心组件和执行流程,提供了一个全面的学习指南。 Spring MVC基于Model-View-Controller(MVC)架构模式,优化...

    Spring MVC MyBatis

    疯狂软件SSM框架的用法,经典著作,分享出来,希望对广大java使用者有用。... C基础,Spring框架基础的读者,尤其适合于对Spring MVC和MyBatis了解不够深入,或对Spring MVC+MyBatis整合开发不太熟悉的开发人员阅读

    互联网轻量级SSM框架解密:Spring、Spring MVC、MyBatis源码深度剖析

    《互联网轻量级SSM框架解密:Spring、Spring MVC、MyBatis源码深度剖析》以SSM 的核心代码剖析为基础,突破Java Web 研发瓶颈的束缚,选取Spring、SpringMVC 和MyBatis 框架中易于理解的版本,深入剖析了其中各个...

    Maven+Hibernate+Spring+Spring MVC开发新闻发布系统

    5、Spring MVC 三、课程目标 1、深入理解Maven工作原理 2、熟练掌握Maven基础应用 3、熟练掌握Maven企业级开发 四、课程大纲 第1课 Maven 概述及安装 第2课 使用Maven构建Java项目 第3课 理解Maven核心概念(一) ...

    互联网轻量级 ssm 框架解密 springspringmvcmybatis源码深度剖析

    《互联网轻量级SSM框架解密:Spring、Spring MVC、MyBatis源码深度剖析》以SSM 的核心代码剖析为基础,突破Java Web 研发瓶颈的束缚,选取Spring、SpringMVC 和MyBatis 框架中易于理解的版本,深入剖析了其中各个...

    Spring 3.0就这么简单源代码

    本书主要介绍了Spring 3.0的核心内容,不仅讲解了Spring 3.0的基础知识,还深入讨论了Spring IoC容器、Spring AOP、使用Spring JDBC访问数据库、集成Hibernate、Spring的事务管理、Spring MVC、单元测试、敏捷开发...

    ssm(spring+spring mvc+mybatis+maven)高仿bilibili视频网站项目实例.zip

    SSM(Spring + Spring MVC + MyBatis)框架作为Java开发中的黄金组合,为开发者提供了强大的技术支持和丰富的功能。本系列资料将带您从零基础开始,逐步掌握SSM的核心技术和最佳实践,助您在Java Web开发领域更上一...

    [Struts 2权威指南--基于WebWork核心的MVC开发(高清完整版) 1/12

    不用多说了,Struts 2权威指南--基于WebWork核心的MVC开发(高清完整版),解压出来有200多M,因为权限不怎么够,我一共分了12卷,是一本不可多得的好书。第一卷附目录: 第1章 Struts 2概述,第2章 Struts 2下的Hello...

    Struts_2+Spring_3+Hibernate整合开发.part5.rar

    第二部分详细讲解Struts 2.2、Spring 3.0和Hibernate 3.6三个框架的用法,介绍三个框架时,从Eclipse IDE的使用来上手,一步步带领读者深入三个框架的核心。这部分内容是笔者讲授“疯狂Java实训”的培训讲义,因此是...

    spring基础进阶技巧200篇.zip

    Spring核心模块:详细介绍了Spring的核心模块,如IoC容器、AOP、Bean管理等。 Spring MVC:介绍了Spring MVC框架的使用方法和技巧,包括控制器、视图解析器、数据绑定等。 Spring Boot:介绍了Spring Boot框架的使用...

    看透springMvc源代码分析与实践.pdf

    国内资深Web开发专家根据Spring MVC全新技术撰写,基于实际生产环境,从基础知识、源代码和实战3个维度对Spring MVC的结构和实现进行详细讲解 全面介绍Spring MVC的架构、原理、核心概念和操作,通过案例完整呈现...

    struts+hibernate+spring

    Spring是一个开源的框架,它的内容非常丰富,从实现了MVC的Spring Web MVC、表现曾的Spring标签,到Spring AOP、核心的LoC等,需要理解的概念也非常多; Hibernate架起了Java对象与数据库中的关系型数据的桥梁,它...

    javaSpring学习笔记

    在“Java Spring学习笔记”中,你将找到对Spring框架的全面介绍,包括IoC(控制反转)和DI(依赖注入)原理、AOP(面向切面编程)、Spring MVC、Spring Boot等核心内容。每个主题都结合了理论知识和实际示例,帮助你...

    Struts_2+Spring_3+Hibernate整合开发.part3.rar

    第二部分详细讲解Struts 2.2、Spring 3.0和Hibernate 3.6三个框架的用法,介绍三个框架时,从Eclipse IDE的使用来上手,一步步带领读者深入三个框架的核心。这部分内容是笔者讲授“疯狂Java实训”的培训讲义,因此是...

    spring5-samples:《Spring5核心原理与30个类手写实战》随书代码示例工程

    《Spring5核心原理与30个类手写实战》4个月销量破万,连续占据畅销榜京东购买链接:当当购买链接:倾注十年Spring研究精华与见解★本书几乎涵盖在Spring应用中可能遇到的所有问题,核心原理(IoC、DI、AOP、MVC)、...

    SSM整合——基于 IDEA Maven项目的 Spring + SpringMVC + MyBatis MVC架构整合.zip

    SSM(Spring + Spring MVC + MyBatis)框架作为Java开发中的黄金组合,为开发者提供了强大的技术支持和丰富的功能。本系列资料将带您从零基础开始,逐步掌握SSM的核心技术和最佳实践,助您在Java Web开发领域更上一...

Global site tag (gtag.js) - Google Analytics