完美解决axios跨域请求出错的问题


Posted in Javascript onFebruary 05, 2018

错误信息:

Response to preflight request doesn't pass access control check: No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'http://localhost:9000' is therefore not allowed access. The response had HTTP status code 403

随着前端框架的发展,如今前后端数据分离已经成了趋势,也就是说,前端只需要用ajax请求后端的数据合成页面,后端仅仅提供数据接口,给数据就行,好处就是前端程序员再也不用在自己的本地搭建Web服务器,前端也不需要懂后端语法,后端也不需要懂前端语法,那么简化了开发配置,也降低了合作难度。

常规的GET,POST,PUT,DELETE请求是简单请求(相对于OPTIONS请求),但是OPTIONS有点儿特别,它要先发送请求问问服务器,你要不要我请求呀,要我就要发送数据过来咯(这完全是根据自己的理解写的,如果有误,敬请谅解,请参考阮一峰大神原文。)

在Vue的项目里,Http服务采用Axios,而它正是采用OPTIONS请求。

如果仅仅在header里面加入: 'Access-Control-Allow-Origin':*,是并不能解决问题的,错误就是如文章开头所示。

这儿就需要后台对OPTIONS请求额外处理。

本文以Spring MVC为例:

添加一个拦截器类:

public class ProcessInterceptor implements HandlerInterceptor {

  @Override
  public boolean preHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o) throws Exception {
    httpServletResponse.setHeader("Access-Control-Allow-Origin", "*");
    httpServletResponse.setHeader("Access-Control-Allow-Headers", "Content-Type,Content-Length, Authorization, Accept,X-Requested-With");
    httpServletResponse.setHeader("Access-Control-Allow-Methods","PUT,POST,GET,DELETE,OPTIONS");
    httpServletResponse.setHeader("X-Powered-By","Jetty");

    String method= httpServletRequest.getMethod();
    if (method.equals("OPTIONS")){
      httpServletResponse.setStatus(200);
      return false;
    }
    System.out.println(method);
    return true;
  }
  @Override
  public void postHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, ModelAndView modelAndView) throws Exception {
  }
  @Override
  public void afterCompletion(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, Exception e) throws Exception {
  }
}

在spring-mvx.xml配置Spring 拦截器:

<mvc:interceptors> 
    <bean class="cn.tfzc.ssm.common.innterceptor.ProcessInterceptor"></bean> 
  </mvc:interceptors>

至此,问题已经解决:

完美解决axios跨域请求出错的问题

以上这篇完美解决axios跨域请求出错的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JavaScript 指导方针
Apr 05 Javascript
javascript完美拖拽的实现方法
Sep 29 Javascript
移除AngularJS下URL中的#字符的方法
Jun 19 Javascript
jquery遍历函数siblings()用法实例
Dec 24 Javascript
JavaScript实现购物车基本功能
Jul 21 Javascript
BootStrap中的模态框(modal,弹出层)功能示例代码
Nov 02 Javascript
JS/HTML5游戏常用算法之碰撞检测 地图格子算法实例详解
Dec 12 Javascript
Vue动态面包屑功能的实现方法
Jul 01 Javascript
vue移动端城市三级联动组件使用详解
Jul 26 Javascript
vue实现修改图片后实时更新
Nov 14 Javascript
JavaScript设计模式之策略模式实现原理详解
May 29 Javascript
OpenLayers3实现测量功能
Sep 25 Javascript
vue 页面加载进度条组件实例
Feb 05 #Javascript
JS设计模式之状态模式概念与用法分析
Feb 05 #Javascript
javascript实现获取一个日期段内每天不同的价格(计算入住总价格)
Feb 05 #Javascript
vue实现图片加载完成前的loading组件方法
Feb 05 #Javascript
JS设计模式之策略模式概念与用法分析
Feb 05 #Javascript
Node.js成为Web应用开发最佳选择的原因
Feb 05 #Javascript
Node.js上传文件功能之服务端如何获取文件上传进度
Feb 05 #Javascript
You might like
zen cart新进商品的随机排序修改方法
2010/09/10 PHP
PHP 图片文件上传实现代码
2010/12/29 PHP
php中获取指定IP的物理地址的代码(正则表达式)
2011/06/23 PHP
php中配置文件操作 如config.php文件的读取修改等操作
2012/07/07 PHP
web server使用php生成web页面的三种方法总结
2013/10/28 PHP
PHP使用Mysql事务实例解析
2014/09/08 PHP
PHP判断是否连接上网络的方法
2015/07/01 PHP
Laravel下生成验证码的类
2017/11/15 PHP
Laravel框架实现model层的增删改查(CURD)操作示例
2018/05/12 PHP
获取页面高度,窗口高度,滚动条高度等参数值getPageSize,getPageScroll
2006/09/22 Javascript
JScript中使用ADODB.Stream判断文件编码的代码
2008/06/09 Javascript
jquery dialog键盘事件代码
2010/08/01 Javascript
jQuery的缓存机制浅析
2014/06/07 Javascript
js实现特定位取反原理及示例
2014/06/30 Javascript
基于jQuery实现动态数字展示效果
2015/08/12 Javascript
js滚动条平滑移动示例代码
2016/03/29 Javascript
JQuery validate插件Remote用法大全
2016/05/15 Javascript
IScroll5实现下拉刷新上拉加载的功能实例
2017/08/11 Javascript
jQuery实现的简单动态添加、删除表格功能示例
2017/09/21 jQuery
nodejs实现一个word文档解析器思路详解
2018/08/14 NodeJs
Cocos2d实现刮刮卡效果
2018/12/20 Javascript
微信小程序学习笔记之登录API与获取用户信息操作图文详解
2019/03/29 Javascript
vue+element获取el-table某行的下标,根据下标操作数组对象方式
2020/08/07 Javascript
跟老齐学Python之传说中的函数编写条规
2014/10/11 Python
Python3解释器知识点总结
2019/02/19 Python
Python使用统计函数绘制简单图形实例代码
2019/05/15 Python
pytorch sampler对数据进行采样的实现
2019/12/31 Python
Python continue语句实例用法
2020/02/06 Python
python 字符串格式化的示例
2020/09/21 Python
越南电子产品购物网站:FPT Shop
2017/12/02 全球购物
内部类的定义、种类以及优点
2013/10/16 面试题
应用英语专业自荐信
2014/01/26 职场文书
医生党的群众路线教育实践活动个人对照检查材料
2014/09/23 职场文书
综合素质评价个性与发展自我评价
2015/03/06 职场文书
茶花女读书笔记
2015/06/29 职场文书
团支部组织委员竞选稿
2015/11/21 职场文书