背景:因为axios中只能使用get和post方法来进行请求数据,没有提供jsonp等方法进行跨域访问数据
axios中文网址:https://www.kancloud.cn/yunye/axios/234845
方案1:既然使用axios直接进行跨域访问不可行,我们就需要配置代理了。代理可以解决的原因:因为客户端请求服务端的数据是存在跨域问题的,而服务器和服务器之间可以相互请求数据,是没有跨域的概念(如果服务器没有设置禁止跨域的权限问题),也就是说,我们可以配置一个代理的服务器可以请求另一个服务器中的数据,然后把请求出来的数据返回到我们的代理服务器中,代理服务器再返回数据给我们的客户端,这样我们就可以实现跨域访问数据。
准备工作:安装所需中间件和插件等,比如axios,http-proxy-middleware等。
具体案例:这里以访问豆瓣Top250为例,直接访问如下:
事实证明直接请求确实出现跨域问题了,下面具体演示解决跨域问题的步骤:
上面所说的必备条件都已安装完成的情况下,执行以下步骤即可解决问题:
1.配置BaseUrl
在main.js中,配置数据所在服务器的前缀(即固定部分),代码如下:
关键代码:axios.defaults.baseURL = '/api',作用是我们每次发送的请求都会带一个/api的前缀。
2.配置代理
在config文件夹下的index.js文件中的proxyTable字段中,作如下处理:
3.在具体使用axios的地方,修改url如下即可:
4.重新启动项目之后,已经解决了跨域问题,结果如下:
原理:
因为我们给url加上了前缀/api,我们访问/movie/top250就当于访问了:localhost:8080/api/movie/top250(其中localhost:8080是默认的IP和端口)。
在index.js中的proxyTable中拦截了/api,并把/api及其前面的所有替换成了target中的内容,因此实际访问Url是http://api.douban.com/v2/movie/top250。
至此,纯前端配置代理解决axios跨域得到解决。
方案2:后端处理跨域问题,加个过滤器即可解决,如下:
以上axios解决跨域的方案,希望能解决大家遇到的跨域问题,如有问题请添加评论。
-------------------------------------------------------------------------分割线-------------------------------------------------------------------------------------
根据评论区内容,区分一下生产环境和开发环境,集体配置如下:
1.在config文件夹里面创建一个api.config.js的配置文件
转自https://blog.csdn.net/wh_xmy/article/details/87705840