一种基于spring拦截器的跨域解决方案

本文详细介绍了如何使用Spring框架的拦截器机制来解决跨域问题,通过配置拦截器,实现允许特定域名或者所有域名的请求访问,提供了一种灵活的跨域处理方式。
摘要由CSDN通过智能技术生成
/**
 * @Description: 跨域支持(在拦截器阶段抛出异常,cross注解不能支持拦截器阶段的跨域,所以在登录拦截器之前先处理跨域支持)
 */
public class CrossInterceptor extends HandlerInterceptorAdapter implements InitializingBean {
    private String accessControlAllowOrigin;

    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        String curOrigin = request.getHeader("Origin");
        if (StringUtils.isNotBlank(curOrigin)) {
            String[] allowUrls = accessControlAllowOrigin.split(",");
            for (String origin : allowUrls) {
                if (origin.equals(curOrigin)) {
                    response.addHeader("Access-Control-Allow-Origin", origin);
                }
            }
        }
        response.addHeader("Access-Control-Allow-Credentials", "true");
        response.setHeader("Access-Control-Allow-Methods", "POST, GET, PUT, OPTIONS, DELETE");
        response.setHeader("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept, Connection, User-Agent, Cookie, Authorization");
        return super.preHandle(request, response, handler);
    }

    @Override
    public void afterPropertiesSet() throws Exception {
        if (StringUtils.isBlank(accessControlAllowOrigin)) {
            throw new RuntimeException("请配置CrossInterceptor跨域支持的host");
        }
    }

    public void setAccessControlAllowOrigin(String accessControlAllowOrigin) {
        this.accessControlAllowOrigin = accessControlAllowOrigin;
    }
}
 

 

<mvc:interceptors>
    <mvc:interceptor>
        <mvc:mapping path="/"/>
        <mvc:mapping path="/**/*"/>
        <bean class="com.web.interceptor.CrossInterceptor">
            <property name="accessControlAllowOrigin" value="${cross.accessControlAllowOrigin}"></property>
        </bean>
    </mvc:interceptor>
</mvc:interceptors>
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值