mvc:view-controller
This tag is a shorcut for defining a ParameterizableViewController that immediately forwards to a view when invoked.
这个标签是为了简化ParameterizableViewController映射到视图的配置Use it in static cases when there is no Java Controller logic to execute before the view generates the response.
当响应视图是不需要执行控制器逻辑时使用An example of view-controller that forwards to a home page is shown below:
一个跳转到主页的配置例子 <mvc:view-controller path="/" view-name="home"/>mvc:resources
This tag allows static resource requests following a particular URL pattern to be served by a ResourceHttpRequestHandler from any of a list of Resource locations. 这个标签允许ResourceHttpRequestHandler从资源列表的位置根据指定的url模板请求静态资源。 This provides a convenient way to serve static resources from locations other than the web application root, including locations on the classpath. 他提供了一个方便的途径来从根目录甚至classpath内读取静态资源 The cache-period property may be used to set far future expiration headers (1 year is the recommendation of optimization tools such as Page Speed and YSlow) so that they will be more efficiently utilized by the client. cache-period属性可以设置很长的缓存时间 The handler also properly evaluates the Last-Modifiedheader (if present) so that a 304 status code will be returned as appropriate, avoiding unnecessary overhead for resources that are already cached by the client. ResourceHttpRequestHandler 根据Last-Modifiedheader (如果设置了)会返回304状态码,避免重复返回以缓存的资源。 For example, to serve resource requests with a URL pattern of /resources/** from a public-resources directory within the web application root, the tag would be used as follows: 例如,通过/resources/**访问根目录下public-resources文件夹下的资源,标签可以像下边这么写: <mvc:resources mapping="/resources/**" location="/public-resources/"/> To serve these resources with a 1-year future expiration to ensure maximum use of the browser cache and a reduction in HTTP requests made by the browser: 设置一年的缓存时间以最大化的利用浏览器缓存和减少服务器压力: <mvc:resources mapping="/resources/**" location="/public-resources/" cache-period="31556926"/> The mapping attribute must be an Ant pattern that can be used by SimpleUrlHandlerMapping, and the location attribute must specify one or more valid resource directory locations. mapping属性必须是可以被SimpleUrlHandlerMapping使用的路径,location属性需指定一个以上正确的目录位置。 Multiple resource locations may be specified using a comma-seperated list of values. 多个资源目录可以使用逗号分隔。 The locations specified will be checked in the specified order for the presence of the resource for any given request. 请求会按配置的顺序依次检测资源目录。 For example, to enable the serving of resources from both the web application root and from a known path of /META-INF/public-web-resources/ in any jar on the classpath, the tag would be specified as: 例如:要想让根目录和classpath下任何jar包的/META-INF/public-web-resources/目录中能够访问,标签可以如下 <mvc:resources mapping="/resources/**" location="/, classpath:/META-INF/public-web-resources/"/> When serving resources that may change when a new version of the application is deployed, it is recommended that you incorporate a version string into the mapping pattern used to request the resources, so that you may force clients to request the newly deployed version of your application's resources. 当新版本的应用部署后资源可能改变,推荐请求资源时在路径中加入版本戳,这样就可以强制客户端请求新版本的应用资源。 Such a version string can be parameterized and accessed using SpEL so that it may be easily managed in a single place when deploying new versions. 版本字符串可以使用SpEL 这样当部署新版本是就可以在指定的位置更轻松的管理。 As an example, let's consider an application that uses a performance-optimized custom build (as recommended) of the Dojo JavaScript library in production, and that the build is generally deployed within the web application at a path of /public-resources/dojo/dojo.js. 举个例子,我们考虑一个应用使用Dojo js类库产品中推荐使用而且性能良好的,通常部署在web应用的/public-resources/dojo/dojo.js Since different parts of Dojo may be incorporated into the custom build for each new version of the application, the client web browsers need to be forced to re-download that custom-built dojo.js resource any time a new version of the application is deployed. ……(翻不出了,上一句也翻的不太对),浏览器需要随时强制下载新版本的dojo.js A simple way to achieve this would be to manage the version of the application in a properties file, such as: 最简单的方法就是在properties文件中管理版本信息,例如: application.version=1.0.0 and then to make the properties file's values accessible to SpEL as a bean using the util:properties tag: 使用util:properties标签把properties文件的内容提供给SpEL <util:properties id="applicationProps" location="/WEB-INF/spring/application.properties"/> With the application version now accessible via SpEL, we can incorporate this into the use of the resources tag: 通过SpEL得到应用的版本,可以把他加入到用到的resources标签: <mvc:resources mapping="/resources-#{applicationProps['application.version']}/**" location="/public-resources/" and finally, to request the resource with the proper URL, we can take advantage of the Spring JSP tags: 最后,可以使用spring jsp标签表示请求资源的url: <spring:eval expression="@applicationProps['application.version']" var="applicationVersion"/> <spring:url value="/resources-{applicationVersion}" var="resourceUrl"> <spring:param name="applicationVersion" value="${applicationVersion}"/> </spring:url> <script src="${resourceUrl}/dojo/dojo.js" type="text/javascript"> </script>
mvc:interceptors
This tag allows you to register custom HandlerInterceptors or WebRequestInterceptors that should be applied to all HandlerMapping beans.
You can also restrict the URL paths specifc interceptors apply to. 这个标签注册自定义的拦截器或请求拦截器 也可以拦截指定url路径An example of registering an interceptor applied to all URL paths:
注册全部url到拦截器: <mvc:interceptors> <bean class="org.springframework.web.servlet.i18n.LocaleChangeInterceptor" /> </mvc:interceptors> An example of registering an interceptor limited to a specific URL path: 注册指定url到拦截器: <mvc:interceptors> <mvc:interceptor> <mapping path="/secure/*"/> <bean class="org.example.SecurityInterceptor" /> </mvc:interceptor> </mvc:interceptors>mvc:default-servlet-handler
Spring参考手册 mvc:default-servlet-handler
This tag allows for mapping the DispatcherServlet to "/" (thus overriding the mapping of the container's default Servlet), while still allowing static resource requests to be handled by the container's default Servlet.
这个标签吧DispatcherServlet 映射到"/"(从而覆盖容器的默认servlet的映射),也允许容器默认的servlet处理静态资源的请求。 //我感觉这句的意思就是:DispatcherServlet把找不到的请求映射到默认的servlet,从而实现处理静态资源的请求。不知理解的对不对?It configures a DefaultServletHttpRequestHandler with a URL mapping (given a lowest precedence order) of "/**".
This handler will forward all requests to the default Servlet. 配置了DefaultServletHttpRequestHandler最后来处理"/**"的请求。 这个处理器会把所有的请求跳转到容器默认servlet。To enable this feature using the default setup, simply include the tag in the form:
标签的默认设置就可以实现这个功能: <mvc:default-servlet-handler/> The caveat to overriding the "/" Servlet mapping is that the RequestDispatcher for the default Servlet must be retrieved by name rather than by path. 覆盖"/"映射会导致默认servlet的RequestDispatcher必须用名字取回而不是路径。(不知道什么意思,是不是跟下一句有关联呐,使用名字找默认servlet)The DefaultServletHttpRequestHandler will attempt to auto-detect the default Servlet for the container at startup time, using a list of known names for most of the major Servlet containers (including Tomcat, Jetty, Glassfish, JBoss, Resin, WebLogic, and WebSphere).
DefaultServletHttpRequestHandler在容器启动是会使用主流web容器默认servlet的名称列表自动查找容器的默认servlet,包括Tomcat, Jetty, Glassfish, JBoss, Resin, WebLogic, and WebSphere。If the default Servlet has been custom configured with a different name, or if a different Servlet container is being used where the default Servlet name is unknown, then the default Servlet's name must be explicitly provided as in the following example:
如果为默认servlet配置了新的名称,或者这个容器servlet名字不在spring列表中是,必须显式配置默认servlet的名字,如下: <mvc:default-servlet-handler default-servlet-name="myCustomDefaultServlet"/>mvc:annotation-driven
This tag registers the DefaultAnnotationHandlerMapping and AnnotationMethodHandlerAdapter beans that are required for Spring MVC to dispatch requests to Controllers.
这个标签注册了Spring MVC分发请求到控制器所必须的DefaultAnnotationHandlerMapping和AnnotationMethodHandlerAdapter实例The tag configures those two beans with sensible defaults based on what is present in your classpath.
标签配置的这2个实例可以根据classpath中的内容默认提供以下功能:The defaults are:
1. Support for Spring 3's Type ConversionService in addition to JavaBeans PropertyEditors during Data Binding. A ConversionService instance produced by the org.springframework.format.support.FormattingConversionServiceFactoryBean is used by default. This can be overriden by setting the conversion-service attribute. 支持spring3的javaBeans属性编辑器数据绑定时的类型转换服务。 类型转换服务实例默认为org.springframework.format.support.FormattingConversionServiceFactoryBean。 可以覆盖conversion-service属性来指定类型转换服务实例类。2. Support for formatting Number fields using the @NumberFormat annotation
支持@NumberFormat 注解格式化数字类型字段。3. Support for formatting Date, Calendar, Long, and Joda Time fields using the @DateTimeFormat annotation, if Joda Time 1.3 or higher is present on the classpath.
@DateTimeFormat注解格式化 Date, Calendar, Long和 Joda Time(如classpath下存在Joda Time 1.3或更高版本)字段4. Support for validating @Controller inputs with @Valid, if a JSR-303 Provider is present on the classpath.
The validation system can be explicitly configured by setting the validator attribute. 支持@Valid注解验证控制器数据,classpath中需JSR-303的**。 可以使用setting明确的配置5. Support for reading and writing XML, if JAXB is present on the classpath.
支持读写xml,classpath中需JAXB 。6. Support for reading and writing JSON, if Jackson is present on the classpath.
支持读写json,classpath中需Jackson 。A typical usage is shown below:
下边是用法:<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="" xmlns:mvc="" xmlns:xsi="" xsi:schemaLocation=""> <!-- JSR-303 support will be detected on classpath and enabled automatically --> <mvc:annotation-driven/> </beans>求上述1-6的使用例子。