voidconfigureContentNegotiation(ContentNegotiationConfigurerconfigurer);
voidaddViewControllers(ViewControllerRegistry registry); voidaddResourceHandlers(ResourceHandlerRegistry registry);
voidconfigureDefaultServletHandling(DefaultServletHandlerConfigurerconfigurer);
1. configureViewResolvers(ViewResolverRegistry registry)
从方法名称我们就能看出这个方法是用来配置视图解析器的,该方法的参数ViewResolverRegistry 是一个注册器,用来注册你想自定义的视图解析器等。ViewResolverRegistry 常用的几个方法:
1).enableContentNegotiation
/** 启用内容裁决视图解析器*/
publicvoidenableContentNegotiation(View... defaultViews) { initContentNegotiatingViewResolver(defaultViews); }
该方法会创建一个内容裁决解析器
ContentNegotiatingViewResolver ,该解析器不进行具体视图的解析,而是管理你注册的所有视图解析器,所有的视图会先经过它进行解析,然后由它来决定具体使用哪个解析器进行解析。具体的映射规则是根据请求的media types来决定的。
2). UrlBasedViewResolverRegistration
publicUrlBasedViewResolverRegistrationjsp(String prefix, String suffix) {
InternalResourceViewResolver resolver = newInternalResourceViewResolver();
resolver.setPrefix(prefix); resolver.setSuffix(suffix); this.viewResolvers.add(resolver);
returnnewUrlBasedViewResolverRegistration(resolver); }
该方法会注册一个内部资源视图解析器
InternalResourceViewResolver 显然访问的所有jsp都是它进行解析的。该方法参数用来指定路径的前缀和文件后缀,如: registry.jsp(\, \);
对于以上配置,假如返回的视图名称是example,它会返回/WEB-INF/jsp/example.jsp给前端,找不到则报404。
3). beanName
publicvoidbeanName() {
BeanNameViewResolver resolver = newBeanNameViewResolver(); this.viewResolvers.add(resolver); }
该方法会注册一个BeanNameViewResolver 视图解析器,这个解析器是干嘛的呢?它主要是将视图名称解析成对应的bean。什么意思呢?假如返回的视图名称是example,它会到spring容器中找有没有一个叫example的bean,
并且这个bean是View.class类型的?如果有,返回这个bean。
4). viewResolver
publicvoidviewResolver(ViewResolverviewResolver) {
if (viewResolverinstanceofContentNegotiatingViewResolver) {
thrownewBeanInitializationException(
\tiatingViewResolver. Please use the method enableContentNegotiation instead.\); }
this.viewResolvers.add(viewResolver); }
这个方法想必看名字就知道了,它就是用来注册各种各样的视图解析器的,包括自己定义的。
2.
configureContentNegotiation(ContentNegotiationConfigurerconfigurer)
上面一节我们讲了configureViewResolvers 方法,假如在该方法中我们启用了内容裁决解析器,那么
configureContentNegotiation(ContentNegotiationConfigurerconfigurer) 这个方法是专门用来配置内容裁决的一些参数的。这个比较简单,
我们直接通过一个例子看:
public void configureContentNegotiation(ContentNegotiationConfigurerconfigurer) {
/* 是否通过请求Url的扩展名来决定media type */ configurer.favorPathExtension(true) /* 不检查Accept请求头 */ .ignoreAcceptHeader(true) .parameterName(\) /* 设置默认的media yype */
.defaultContentType(MediaType.TEXT_HTML) /* 请求以.html结尾的会被当成MediaType.TEXT_HTML*/ .mediaType(\, MediaType.TEXT_HTML)
/* 请求以.json结尾的会被当成MediaType.APPLICATION_JSON*/ .mediaType(\, MediaType.APPLICATION_JSON); }
到这里我们就可以举个例子来进一步熟悉下我们上面讲的知识了,假如我们MVC的配置如下: @EnableWebMvc @Configuration
publicclassMvcConfigextendsWebMvcConfigurerAdapter {
@Override
publicvoidconfigureViewResolvers(ViewResolverRegistry registry) {
registry.jsp(\, \);
registry.enableContentNegotiation(new MappingJackson2JsonView()); }
@Override
publicvoidconfigureContentNegotiation(ContentNegotiationConfigurerconfigurer) {
configurer.favorPathExtension(true) .ignoreAcceptHeader(true) .parameterName(\)
.defaultContentType(MediaType.TEXT_HTML) .mediaType(\, MediaType.TEXT_HTML) .mediaType(\, MediaType.APPLICATION_JSON); } }
controller的代码如下: @Controller
publicclassExampleController { @RequestMapping(\) publicModelAndViewexample1() {