欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

VUE axios发送跨域请求需要注意的问题

程序员文章站 2022-05-26 09:03:17
在实际项目中前端使用到vue,后端使用php进行开发。前端使用axios请求请求 关于跨域 跨域的概念这些就不说了,百度一大堆相关的资料信息。我就只在这里记录下我在...

在实际项目中前端使用到vue,后端使用php进行开发。前端使用axios请求请求

关于跨域

跨域的概念这些就不说了,百度一大堆相关的资料信息。我就只在这里记录下我在使用当中遇到的问题,以纪念在逝去的几个小时中资料查找的艰辛。

不多说,直接上代码~~~~

同理,跨域的解决方案为cros。服务器 php端代码如下(laravel 中间件进行处理):

public function handle($request, closure $next)
  {

    if ($request->ismethod('options')) {
      $response = response('', 200);
    } else {
      $response = $next($request);
    }
    if (!method_exists($response, 'header')) {
      return $response;
    }
    $response->header('access-control-allow-methods', 'head, get, post, put, patch, delete, options');
    $response->header(
      'access-control-allow-headers',
      'content-type, content-length, authorization, accept, x-requested-with, token'
    );
    $response->header('access-control-allow-origin', '*');
    $response->header('access-control-max-age', 86400);
    return $response;
  }

vue端 axios 请求:

axios.post('http://xxxx.com',{name:'test'});

这样写,在请求的时候就会遇到:

VUE axios发送跨域请求需要注意的问题

很坑爹有没有?明明是已经设置好了的啊,为毛是这样???

查找了很多资料才发现,axios在发送数据时需要字符串的方式进行发送,也就是说是放在form-data当中的。在实际项目中,为了方便,我引入了 qs 来帮助处理这块数据:

解决后的代码应该是:

import qs from 'qs';
axios.post('http://xxxxx.com',qs.stringify({name:'test'})).then(re=>{
  console.log(re);
});

ok,问题解决。明明感觉很简单,但是就是因为自己不懂,导致找了很久才知道原因,之前一直在折腾后台的设置,忽略了前端本身的处理。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。