SpringBoot中SpringMVC配置

 

当我们需要对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);
    }

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值