spring mvc配置类简介及放静态资源释放

news/2023/6/9 19:41:51

配置文件ApplicationContext.xml

基于spring的项目资源都是通过DispatcherServlet作为拦截器,DispatcherServlet是前置控制器,配置在web.xml文件中的。拦截匹配的请求,Servlet拦截匹配规则要自己定义,把拦截下来的请求,依据相应的规则分发到目标Controller来处理,是配置spring MVC的第一步。

Alt

DispatcherServlet主要用作职责调度工作,本身主要用于控制流程,主要职责如下:

  1. 文件上传解析,如果请求类型是multipart将通过MultipartResolver进行文件上传解析;
  2. 通过HandlerMapping,将请求映射到处理器(返回一个HandlerExecutionChain,它包括一个处理器、多个HandlerInterceptor拦截器);
  3. 通过HandlerAdapter支持多种类型的处理器(HandlerExecutionChain中的处理器);
  4. 通过ViewResolver解析逻辑视图名到具体视图实现;
  5. 本地化解析;
  6. 渲染具体的视图等;
  7. 如果执行过程中遇到异常将交给HandlerExceptionResolver来解析。
    DispatcherServlet初始化的上下文加载的Bean是只对SpringMVC有效的Bean,
    如Controller、HandlerMapping、HandlerAdapter等等,该初始化上下文只加载Web相关组件。

DispatcherServlet初始化主要做了如下两件事情:
1、初始化SpringMVC使用的Web上下文,并且可能指定父容器为(ContextLoaderListener加载了根上下文);
2、初始化DispatcherServlet使用的策略,如HandlerMapping、HandlerAdapter等。

DispatcherServlet中使用的特殊的Bean:
DispatcherServlet默认使用WebApplicationContext作为上下文,该上下文中特殊的Bean有:
1、Controller:
处理器/页面控制器,做的是MVC中的C的事情,但控制逻辑转移到前端控制器了,用于对请求进行处理;
2、HandlerMapping:
请求到处理器的映射,如果映射成功返回一个HandlerExecutionChain对象
(包含一个Handler处理器(页面控制器)对象、多个HandlerInterceptor拦截器)对象;
如BeanNameUrlHandlerMapping将URL与Bean名字映射,映射成功的Bean就是此处的处理器;
3、HandlerAdapter:
HandlerAdapter将会把处理器包装为适配器,从而支持多种类型的处理器,即适配器设计模式的应用,
从而很容易支持很多类型的处理器;
如SimpleControllerHandlerAdapter将对实现了Controller接口的Bean进行适配,
并且按处理器的handleRequest方法进行功能处理;
4、ViewResolver:
ViewResolver将把逻辑视图名解析为具体的View,通过这种策略模式,很容易更换其他视图技术;
如InternalResourceViewResolver将逻辑视图名映射为jsp视图;
5、LocalResover:
本地化解析,因为Spring支持国际化,因此LocalResover解析客户端的Locale信息从而方便进行国际化;
6、ThemeResovler:
主题解析,通过它来实现一个页面多套风格,即常见的类似于软件皮肤效果;
7、MultipartResolver:
文件上传解析,用于支持文件上传;
8、HandlerExceptionResolver:
处理器异常解析,可以将异常映射到相应的统一错误界面,从而显示用户友好的界面(而不是给用户看到具体的错误信息);
9、RequestToViewNameTranslator:
当处理器没有返回逻辑视图名等相关信息时,自动将请求URL映射为逻辑视图名;

在这里插入图片描述

SSM配置文件的释放资源
SSM项目是离不开配置文件的,配置文件修改也是最简单的一种修改方式:Spring mvc释放静态资源的方法

通过配置文件添加配置信息覆盖默认即可释放静态资源。

<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"><property name="prefix" value="/"></property><property name="suffix" value=".jsp"></property></bean>

配置中添加这个这个在返回时View时更加方便,例如return "/index.jsp"可以直接写成return "index"

基于配置类WebMvcConfigurer

该配置类是spring提供的一种配置方式,采用JavaBean的方式替代传统的基于xml的配置来对spring框架进行自定义的配置。因此,在spring boot提倡的基于注解的配置,采用“约定大于配置”的风格下,当需要进行自定义的配置时,便可以使用WebMvcConfigurer接口或者继承该接口,或者其实现类WebMvcConfigurerAdapter这个抽象类等等,通过JavaBean来实现需要的配置。

也就是说WebMvcConfigurer是ApplicationContext.xml的配置类版。

除了上面的配置文件也可以使用注解来更改配置,WebMvcConfigurer是MVC的配置类接口。
在这里插入图片描述
该接口定义了许多方法用于修改配置,源码如下:

public interface WebMvcConfigurer {void configurePathMatch(PathMatchConfigurer var1);void configureContentNegotiation(ContentNegotiationConfigurer var1);void configureAsyncSupport(AsyncSupportConfigurer var1);void configureDefaultServletHandling(DefaultServletHandlerConfigurer var1);void addFormatters(FormatterRegistry var1);void addInterceptors(InterceptorRegistry var1);void addResourceHandlers(ResourceHandlerRegistry var1);void addCorsMappings(CorsRegistry var1);void addViewControllers(ViewControllerRegistry var1);void configureViewResolvers(ViewResolverRegistry var1);void addArgumentResolvers(List<HandlerMethodArgumentResolver> var1);void addReturnValueHandlers(List<HandlerMethodReturnValueHandler> var1);void configureMessageConverters(List<HttpMessageConverter<?>> var1);void extendMessageConverters(List<HttpMessageConverter<?>> var1);void configureHandlerExceptionResolvers(List<HandlerExceptionResolver> var1);void extendHandlerExceptionResolvers(List<HandlerExceptionResolver> var1);Validator getValidator();MessageCodesResolver getMessageCodesResolver();
}

可以通过该接口添加一些自定义的拦截器,例如跨域设置、类型转化器等,下面是其常用方法
在这里插入图片描述

 /* 拦截器配置 */
void addInterceptors(InterceptorRegistry var1);
/* 视图跳转控制器 */
void addViewControllers(ViewControllerRegistry registry);
/***静态资源处理
**/
void addResourceHandlers(ResourceHandlerRegistry registry);
/* 默认静态资源处理器 */
void configureDefaultServletHandling(DefaultServletHandlerConfigurer configurer);
/*** 这里配置视图解析器**/
void configureViewResolvers(ViewResolverRegistry registry);
/* 配置内容裁决的一些选项*/
void configureContentNegotiation(ContentNegotiationConfigurer configurer);
/** 解决跨域问题 **/
public void addCorsMappings(CorsRegistry registry) ;

继承WebMvcConfigurer后就可以在该类自定配置,也可以继承其实现类WebMvcConfigurerAdapter扩展了更多方法。但是Spring5.0废弃了WebMvcConfigurerAdapter,不过WebMvcConfigurer存在的方法也满足基本使用。

和配置文件注册加载Bean一样,先定义后依赖注入在自动装配。通过WebMvcConfigurer的继承类实现也是同样的步骤:

//定义拦截器
public class LoginInterceptor extends HandlerInterceptorAdapter {private static final Logger logger = LoggerFactory.getLogger(LoginInterceptor.class);@Overridepublic boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {logger.info("-----------------------------");logger.info(request.getRequestedSessionId());logger.info("-----------------------------");return true;}
}
@Configuration
public class WebConfig extends WebMvcConfigurerAdapter {/** 拦截器配置*/@Overridepublic void addInterceptors(InterceptorRegistry registry) {registry.addInterceptor(new LoginInterceptor()).addPathPatterns("/**");
}
//跨域CORS配置public void addCorsMappings(CorsRegistry registry) {super.addCorsMappings(registry);registry.addMapping("/**").allowedHeaders("*").allowedMethods("POST","GET").allowedOrigins("http://...").allowCredentials(true);}//配置ViewController/*** 视图控制器配置* @param registry*/@Overridepublic void addViewControllers(ViewControllerRegistry registry) {super.addViewControllers(registry);registry.addViewController("/").setViewName("forward:/index.html");}//配置ViewResolver
/*** 配置请求视图映射** @return*/@Beanpublic InternalResourceViewResolver resourceViewResolver() {InternalResourceViewResolver internalResourceViewResolver = new InternalResourceViewResolver();//请求视图文件的前缀地址internalResourceViewResolver.setPrefix("/WEB-INF/jsp/");//请求视图文件的后缀internalResourceViewResolver.setSuffix(".jsp");return internalResourceViewResolver;}@Overridepublic void configureViewResolvers(ViewResolverRegistry registry) {super.configureViewResolvers(registry);registry.viewResolver(resourceViewResolver());}//配置Formatter
@Overridepublic void addFormatters(FormatterRegistry registry) {registry.addFormatter(new Formatter<Date>() {@Overridepublic Date parse(String date, Locale locale) {return new Date(Long.parseLong(date));}@Overridepublic String print(Date date, Locale locale) {return Long.valueOf(date.getTime()).toString();}});}

在ssm项目中我们知道控制器对静态资源的拦截是通过继承WebMvcConfigurationSupport
WebMvcConfigurationSupport是webmvc的配置类,如果在springboot项目中,有配置类继承了WebMvcConfigurationSupport,那么webmvc的自动配置类WebMvcAutoConfiguration就会失效。

该类就有配置功能,如释放静态资源:

public class WebMvcConfiguration extends WebMvcConfigurationSupport {private static final String[] CLASSPATH_RESOURCE_LOCATIONS = {"classpath:/META-INF/resources/", "classpath:/resources/","classpath:/static/", "classpath:/public/"};@Overridepublic void addResourceHandlers(ResourceHandlerRegistry registry) {if (!registry.hasMappingForPattern("/webjars/**")) {registry.addResourceHandler("/webjars/**").addResourceLocations("classpath:/META-INF/resources/webjars/");}if (!registry.hasMappingForPattern("/**")) {registry.addResourceHandler("/**").addResourceLocations(CLASSPATH_RESOURCE_LOCATIONS);}}
}

其他常用方法:

@Configuration
public class MyConfig extends WebMvcConfigurationSupport{//自定义的一个拦截器@AutowiredHttpInterceptor httpInterceptor;//定义时间格式转换器@Beanpublic MappingJackson2HttpMessageConverter jackson2HttpMessageConverter() {MappingJackson2HttpMessageConverter converter = new MappingJackson2HttpMessageConverter();ObjectMapper mapper = new ObjectMapper();mapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);mapper.setDateFormat(new SimpleDateFormat("yyyy-MM-dd hh:mm:ss"));converter.setObjectMapper(mapper);return converter;}//添加转换器//配置springmvc返回数据时 输出数据的格式,这里只配置了时间的输出格式@Overridepublic void configureMessageConverters(List<HttpMessageConverter<?>> converters) {//将我们定义的时间格式转换器添加到转换器列表中,//这样jackson格式化时候但凡遇到Date类型就会转换成我们定义的格式converters.add(jackson2HttpMessageConverter());}@Overrideprotected void addInterceptors(InterceptorRegistry registry) {// TODO Auto-generated method stub//将我们自定义的拦截器注册到配置中 registry.addInterceptor(httpInterceptor).addPathPatterns("/**");super.addInterceptors(registry);}   /*** 防止@EnableMvc把默认的静态资源路径覆盖了,手动设置的方式* 配置了静态资源访问* 还能配置视图解析 访问服务器上的资源* @param registry*/@Overrideprotected void addResourceHandlers(ResourceHandlerRegistry registry) {// 解决静态资源无法访问registry.addResourceHandler("/**").addResourceLocations("classpath:/static/");//配置视图解析,把url中后面带/image/***的路径映射到c盘photo文件中的资源registry.addResourceHandler("/image/**").addResourceLocations("file:C://photo/");super.addResourceHandlers(registry);}//配置服务器跨域请求被允许@Overridepublic void addCorsMappings(CorsRegistry registry) {registry.addMapping("/**").allowedOrigins("*").allowedMethods("GET", "POST", "PUT", "OPTIONS", "DELETE", "PATCH").allowCredentials(true).maxAge(3600);}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.exyb.cn/news/show-4560714.html

如若内容造成侵权/违法违规/事实不符,请联系郑州代理记账网进行投诉反馈,一经查实,立即删除!

相关文章

Lingke: A Fine-grained Multi-turn Chatbot for Customer Service

最近做问答系统领域&#xff0c;要求自己每天读一篇论文&#xff0c;为帮助自己理解和记忆&#xff0c;将要点记录在博客上 摘要 机器人类型&#xff1a;信息检索型机器人&#xff08;给一段资料回答问题&#xff09;特色功能&#xff1a;1)基于给定的产品说明书回答问题&#…

LeetCode刷题EASY篇Linked List Cycle

题目 判断一个链表是否有环 Given a linked list, determine if it has a cycle in it. Follow up: Can you solve it without using extra space? 我的尝试 没有思路 正确解法 1.利用额外空间 利用set存储访问过的节点&#xff0c;如果已经访问过&#xff0c;表示有环…

ArrayList与LinkedList区别

一般大家都知道ArrayList和LinkedList的大致区别&#xff1a;1.ArrayList是实现了基于动态数组的数据结构&#xff0c;LinkedList基于链表的数据结构。2.对于随机访问get和set&#xff0c;ArrayList觉得优于LinkedList&#xff0c;因为LinkedList要移动指针。实现了Queue接口。…

STM32F103和AIR32F103的FreeRTOS中断优先级

关于 Arm Cortex M 系列内核的中断优先级 Cortex M 的中断和优先级 首先要区分开 中断 和 中断优先级 这是两个不同的东西, 不要搞混了 对于 Cortex-M0 和 Cortex-M0 内核, 除了系统内建中断外, 支持最多 32 个中断对于 Cortex-M3 内核, 除了 16 个内核中断外, 支持最多 240…

mysql索引linke和等于_MySQL索引怎么用?秒懂只需四个点!

一、前言在MySQL中进行SQL优化的时候&#xff0c;经常会在一些情况下&#xff0c;对MySQL能否利用索引有一些迷惑。譬如:1.MySQL 在遇到范围查询条件的时候就停止匹配了&#xff0c;那么到底是哪些范围条件&#xff1f;2.MySQL 在LIKE进行模糊匹配的时候又是如何利用索引的呢&a…

Paxos共识算法详解

在一个分布式系统中&#xff0c;由于节点故障、网络延迟等各种原因&#xff0c;根据CAP理论&#xff0c;我们只能保证一致性&#xff08;Consistency&#xff09;、可用性&#xff08;Availability&#xff09;、分区容错性&#xff08;Partition Tolerance&#xff09;中的两个…

共识算法 PBFT浅析

PBFT是PracticalByzantine Fault Tolerance的缩写&#xff0c;意为实用拜占庭容错算法。该算法是Miguel Castro (卡斯特罗)和Barbara Liskov&#xff08;利斯科夫&#xff09;在1999年提出来的&#xff0c;解决了原始拜占庭容错算法效率不高的问题&#xff0c;将算法复杂度由指…