javaweb项目ajax的跨域访问问题

在做项目中遇到了ajax的跨域访问,寻求了好多时间,在不懈努力之下终于发现了解决办法,与一般的不同的是,我是在服务器端利用拦截器进行控制,即在每一次的请求中拦截器强制的加入Access-Control-Allow-Origin操作权限,我的项目的架构采用SpringMVC+Mybatis 前台采用jQuery 和HTML5。

问题描述
在一般发送ajax请求的时候使用的数据格式是json,如果跨域,一般人考虑到的是jsonp,但是有些项目中如果使用jsonp的话,在封装数据的时候就要重新写好多的方法,这无疑增加了工作量。
这样的写后果就是报如下错误:
跨域错误
解决方案
1.客户端写法:
客户端写法
2.服务端写法:
服务端写法
3.编写拦截器:
拦截器
4.配置拦截器:
配置拦截器
拦截器代码:

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.handler.HandlerInterceptorAdapter;
/**
 * 解决跨域请求的拦截器
 * @author weiqiang
 *
 */
public class AccessKeyInterceptor extends HandlerInterceptorAdapter {

    private static Log log = LogFactory.getLog(AccessKeyInterceptor.class);

    /**
     * preHandle方法是进行处理器拦截用的,顾名思义,该方法将在Controller处理之前进行调用,
     * SpringMVC中的Interceptor拦截器是链式的,可以同时存在多个Interceptor,
     * 然后SpringMVC会根据声明的前后顺序一个接一个的执行,
     * 而且所有的Interceptor中的preHandle方法都会在Controller方法调用之前调用。
     * SpringMVC的这种Interceptor链式结构也是可以进行中断的,
     * 这种中断方式是令preHandle的返回值为false,当preHandle的返回值为false的时候整个请求就结束了。
     */
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        String referer = request.getHeader("Referer");
        String host = request.getRemoteHost();
        //手机端访问时间referer为空
        if (referer == null) {
            response.setHeader("Access-Control-Allow-Origin","");
            return true;
        } else {
            // URL u = new URL(referer);
            // String host = u.getHost().toLowerCase();
            //s是跨域请求地址的IP
            String s = "192.168.100.28";
            if (host.matches(s)) {
                //添加跨域访问权限
                response.setHeader("Access-Control-Allow-Origin",referer.substring(0, 21));
            }
            response.setHeader("Access-Control-Allow-Headers", "Content-Type");
            response.setHeader("Access-Control-Allow-Methods", "GET");
            response.setHeader("Allow", "GET");
            return true;
        }
    }

    /**
     * 这个方法只会在当前这个Interceptor的preHandle方法返回值为true的时候才会执行。
     * postHandle是进行处理器拦截用的,它的执行时间是在处理器进行处理之 后, 也就是在Controller的方法调用之后执行,
     * 然后要在Interceptor之前调用的内容都写在调用invoke之前,要在Interceptor之后调用的内容都写在调用invoke方法之后。
     */
    @Override
    public void postHandle(HttpServletRequest request,
            HttpServletResponse response, Object handler,
            ModelAndView modelAndView) throws Exception {
    }

    /**
     * 该方法也是需要当前对应的Interceptor的preHandle方法的返回值为true时才会执行
     */
    @Override
    public void afterCompletion(HttpServletRequest request,
            HttpServletResponse response, Object handler, Exception ex) {
        String host = request.getRemoteHost();
        log.debug("IP为---->>> " + host + " <<<-----访问成功");
    }

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值