javascript - axios无法发起跨域请求
PHPz
PHPz 2017-04-11 12:38:17
0
3
672

具体情况看截图

我封装了一个ajax模块,源码如下

import axios from 'axios' import Qs from 'qs' export default { post: function (url, data) { axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded'; let config = { //请求的接口,在请求的时候,如axios.get(url,config);这里的url会覆盖掉config中的url url: url, // 请求方法同上 method: 'post', // default // 基础url前缀 baseURL: 'http://127.0.0.1/netdisk/public/',    transformRequest: [function (data) { // 这里可以在发送请求之前对请求数据做处理,比如form-data格式化等,这里可以使用开头引入的Qs(这个模块在安装axios的时候就已经安装了,不需要另外安装)   data = Qs.stringify({}); return data; }], transformResponse: [function (data) { // 这里提前处理返回的数据 return data; }], // 请求头信息 headers: {'X-Requested-With': 'XMLHttpRequest'}, //parameter参数 params: { timestamp: Date.parse(new Date()) / 1000 }, //post参数,使用axios.post(url,{},config);如果没有额外的也必须要用一个空对象,否则会报错 data: data, //设置超时时间 timeout: 5000, //返回数据类型 responseType: 'json', // default } return axios.post(url, data, this.config) } }

然后在组件内部使用

this.ajax.post(url, form) .then(function (res) { console.log(res) }) .catch(function (err) { console.log(err) })

调用失败,报上图错误,这是怎么回事呢?
我服务器设置了CORS头部为*,并且在其他地方使用file标签跨域上传文件成功了,说明服务器设置没问题,现在问题应该是出在vue.js部分,但是究竟是啥问题呢?

PHPz
PHPz

学习是最好的投资!

모든 응답 (3)
Ty80

你应该只设置了Access-Control-Allow-Origin:*
根据报错提示,你还需要添加"Access-Control-Allow-Headers":"Authorization,Origin, X-Requested-With, Content-Type, Accept"来设置允许跨域的http请求头(具体根据你的代码来定)
类似的还有"Access-Control-Allow-Methods":"GET,POST"
`

    Peter_Zhu

    const instance = axios.create({

    baseURL: 'http://dev.xxxxxxxxxxx.com/', headers:{ 'Content-Type':'application/x-www-form-urlencoded' }, transformRequest: [function (data) { data = Qs.stringify(data); return data; }], withCredentials:true //加了这段就可以跨域了

    });

    看我的注释
    或者如下 后面加withCredentials:true
    axios.get('http://dev.xxxxxxxxxxxxxxx',{withCredentials:true}).then。。。。。。

    因为我之前遇到这个问题了

      Ty80

      跨域需要使用jsonp而不是json吧

        최신 다운로드
        더>
        웹 효과
        웹사이트 소스 코드
        웹사이트 자료
        프론트엔드 템플릿
        회사 소개 부인 성명 Sitemap
        PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!