springmvc配置

mvc拦截器的实现:
@Configuration
public class WebConfig implements WebMvcConfigurer {
@Autowired
LoginInterceptor loginInterceptor;
//实现拦截器
@Override
public void addInterceptors(InterceptorRegistry registry) {
registry.addInterceptor(loginInterceptor).addPathPatterns(“/test”).addPathPatterns(“/comments/create/change”).addPathPatterns(“/articles/publish”);
}

//跨域配置,使前后端分离,让前端端口访问后端端口
@Override
public void addCorsMappings(CorsRegistry registry) {

// registry.addMapping(“/“).allowedOrigins(“http://localhost:8080”).allowedOrigins(“http://anyukf.cn”);
registry.addMapping(”/
”).allowedOrigins(“*”);
}
}
我们需要对SpringMVC进行扩展的时候,对比如说增加一个拦截器或者新建一个参数绑定,这个时候就得通过继承WebMvcConfigurerAdapter然后重写父类中的方法进行扩展

自定义参数转换器
正常情况下,前端传递来的参数都能直接被SpringMVC接收,但是也会遇到一些特殊情况,比如Date对象,当我的前端传来的一个日期时,就需要服务端自定义参数绑定,将前端的日期进行转换。自定义参数绑定也很简单,分两个步骤:

自定义参数转换器实现Converter接口,如下:

public class DateConverter implements Converter<String,Date> {
private SimpleDateFormat simpleDateFormat = new SimpleDateFormat(“yyyy-MM-dd”);
@Override
public Date convert(String s) {
if (“”.equals(s) || s == null) {
return null;
}
try {
return simpleDateFormat.parse(s);
} catch (ParseException e) {
e.printStackTrace();
}
return null;
}
}
convert方法接收一个字符串参数,这个参数就是前端传来的日期字符串,这个字符串满足yyyy-MM-dd格式,然后通过SimpleDateFormat将这个字符串转为一个Date对象返回即可。

配置转换器

自定义WebMvcConfig继承WebMvcConfigurer,在addFormatters方法中进行配置:

@Configuration
public class WebMvcConfig extends WebMvcConfigurerAdapter {
@Override

@Override
public void configureMessageConverters(List<HttpMessageConverter<?>> converters) {
converters.addConverter(new DateConverter());
super.addDefaultHttpMessageConverters(converters); //需要加上默认的convert
}

}
OK,如上两步之后,我们就可以在服务端接收一个前端传来的字符串日期并将之转为Java中的Date对象了

2.拦截器
生成拦截器,实现HandlerInterceptor接口,实现其中的方法。共有三个方法。如下:

public class MyIntecter implements HandlerInterceptor{
/**
* controller执行前调用,为FALSE则controller不执行
/
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
throws Exception {
System.out.println(“执行之前调用”);
return true;
}
/
*
* controller调用之后执行,且页面渲染之前调用
/
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler,
ModelAndView modelAndView) throws Exception {
System.out.println(“执行之后调用”);
}
/
*
* 页面渲染之后调用,一般用于资源清理操作
*/
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex)
throws Exception {

}

}

将拦截器加入到Spring容器中:

@Configuration
public class SpringMVCConfig extends WebMvcConfigurer{

@Override
public void addInterceptors(InterceptorRegistry registry) {
	registry.addInterceptor(new MyIntecter());
}

}
3.配置静态资源
默认有/static,/public/resource,需要修改可以使用下面方法

spring:
mvc:
static-path-pattern: /static/**
resources:
static-locations: classpath:/static/
一开始用配置文件配置,但一直没有生效,可能是由于名字改了,后台使用java配置方式

@Override
public void addResourceHandlers(ResourceHandlerRegistry registry) {
if(!registry.hasMappingForPattern(“/static/“)){
registry.addResourceHandler(”/static/
”).addResourceLocations(“classpath:/static/”);
}
}
4 filter 配置
@Order
@WebFilter(urlPatterns = “login/*”)
public class TempFilter implements Filter {
@Override
public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
System.out.println(“temp filter exec”);
HttpServletRequest request= (HttpServletRequest) servletRequest;
System.out.println(request.getRequestURI());
filterChain.doFilter(servletRequest,servletResponse);
}
}
然后再启动类上加上这个注解就可以了。

@ServletComponentScan
或者直接在filter上加上@Component也行,与上述方法只要有一个即可,如果都有的话,会导致过滤俩遍

5 设置跨域

@Override
public void addCorsMappings(CorsRegistry registry) {
registry.addMapping(“/**”)
.allowedOrigins(“*”)
.allowedMethods(“OPTIONS”, “GET”, “POST”, “DELETE”)
.allowedHeaders(
“X-CustomHeader”, “Keep-Alive”, “User-Agent”, “X-Requested-With”, “If-Modified-Since”,
“Cache-Control”, “Content-Type”, “account_id”,“Accept”,“Accept-Encoding”,“Accept-Language”,
“Connection”,“Content-Length”,“Host”,“Origin”,“Pragma”,“Referer”)
.allowCredentials(true).maxAge(3600);
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值