springBoot 拦截配置

最近重构公司项目发现之前项目中有很多的拦截配置,用的大部分都是shiro进行拦截,将项目升级成boot项目之后试着shiro的方式半天,后来发现boot项目自带拦截,有点捡来芝麻丢了西瓜的感觉,好了废话不多说之间上代码:
1、继承 WebMvcConfigurerAdapter 实现方法
WebMvcConfigurerAdapter配置类其实是Spring内部的一种配置方式,采用JavaBean的形式来代替传统的xml配置文件形式进行针对框架个性化定制,Spring 5.0 以后WebMvcConfigurerAdapter会取消掉
以下WebMvcConfigurerAdapter 比较常用的重写接口 
/** 解决跨域问题 **/ public void addCorsMappings(CorsRegistry registry) ;
/** 添加拦截器 **/ void addInterceptors(InterceptorRegistry registry); 
/** 这里配置视图解析器 **/ void configureViewResolvers(ViewResolverRegistry registry);
/** 配置内容裁决的一些选项 **/ void configureContentNegotiation(ContentNegotiationConfigurer configurer); 
/** 视图跳转控制器 **/ void addViewControllers(ViewControllerRegistry registry);
/** 静态资源处理 **/ void addResourceHandlers(ResourceHandlerRegistry registry); 
/** 默认静态资源处理器 **/ void configureDefaultServletHandling(DefaultServletHandlerConfigurer configurer);

新的版本解决方案目前有两种:
方案1 直接实现WebMvcConfigurer
@Configuration
public class WebMvcConfg implements WebMvcConfigurer {
    @Override
    public void addViewControllers(ViewControllerRegistry registry) {
         registry.addViewController("/index").setViewName("index");
    }
}
方案2 直接继承WebMvcConfigurationSupport
@Configuration
public class WebMvcConfg extends WebMvcConfigurationSupport {
   @Override
   public void addViewControllers(ViewControllerRegistry registry) {
        registry.addViewController("/index").setViewName("index");
   }
}
个人推荐使用第一种
/**
 * 跨域配置 允许所以请求进来,可根据需求配置
 * @param registry
 */
@Override
public void addCorsMappings(CorsRegistry registry) {
    registry.addMapping("/**").allowedHeaders("*")
            .allowedMethods("*")
            .allowedOrigins("*")
            .maxAge(3628800)
            .allowCredentials(true);
}
/**
 * 拦截器配置 拦截所需要拦截的请求,走addInterceptor内new的方法校验
 * @param registry
 */
@Override
public void addInterceptors(InterceptorRegistry registry){
    if(!devWithoutInterception) {
        registry.addInterceptor(new UserInterceptor())
                .addPathPatterns("/user/*.do", "/order/*.do")
                .excludePathPatterns("/common/*.do", "/wechat/*.do");
        registry.addInterceptor(new WebRequestInterceptor())
                .addPathPatterns("/html/*.do")
                .excludePathPatterns("/common/*.do");
    }
}
/**
 * FilterRegistrationBean
 * 用来配置urlpattern
 * 来确定哪些路径触发filter
 * order 顺序
 */
@Bean
public FilterRegistrationBean someFilterRegistration() {
    FilterRegistrationBean registration = new FilterRegistrationBean();
    registration.setFilter(new DecryptFilter());
    registration.addUrlPatterns("/user/*","/order/*");
    registration.setOrder(1);
    return registration;
}
/**
 * 配置微信访问拦截
 * @return
 */
@Bean
public ServletRegistrationBean indexServletRegistration() {
    ServletRegistrationBean registration = new ServletRegistrationBean(new AccessTokenServlet());
    registration.addUrlMappings("/AccessTokenServlet");
    registration.addInitParameter("appId",wxappid);
    registration.addInitParameter("appSecret",wxappSecret);
    return registration;
}
/**
 * 在Springboot程序启动后,会默认添加OrderedCharacterEncodingFilter和HiddenHttpMethodFilter过滤器。
 * 在HiddenHttpMethodFilter过滤器中会调用request.getParameter(),
 * 从而造成我们在controller中通过request的InputStream无法读取到RequestBody的数据
 * @return
 */
@Bean
public HiddenHttpMethodFilter hiddenHttpMethodFilter() {
    return new OrderedHiddenHttpMethodFilter(){
        @Override
        protected void doFilterInternal(HttpServletRequest request, HttpServletResponse response, FilterChain filterChain)
                throws ServletException, IOException {
            filterChain.doFilter(request, response);
        }
    };
}

以上部分原创其余则是参考别人敬请谅解。

 

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值