详解Vue 开发模式下跨域问题
程序员文章站
2022-06-24 17:15:12
设置请求头部
后端设置请求头部access-control-allow-credentials: true和access-control-allow-origin...
设置请求头部
- 后端设置请求头部
access-control-allow-credentials: true
和access-control-allow-origin: www.xxx.com
- 前端post请求设置
withcredentials=true
- 这里用了axios的请求数据方法代码如下:
import axios from 'axios' import config from '../config' export default { request (method, uri, data, headerconfig = {withcredentials: true}) { if (!method) { console.error('api function call requires method argument') return } if (!uri) { console.error('api function call requires uri argument') return } let url = config.serveruri + uri return axios({ method, url, data, ...headerconfig }) } }
jquery的$.ajax::
$.ajax({ type: "post", url: "http://www.xxx.com/api.php", datatype: 'json', xhrfields: { withcredentials: true }, crossdomain: true }).then((json) => { // balabala... })
使用nodejs做代理
- 上面的那种方法需要后端配合设置头部,对于我这种前端小白来讲,联调时各种不成功的报错也无从解决,所以个人比较倾向于下面这种做法,鉴于使用脚手架vue-cli创建的项目,作者已经给我提供好了解决的方法。
- 找到项目文件夹下的config/index.js, 里面有一行proxytable: {}, 这里就是作者为我们留的接口, 我们添加代理规则进去
var path = require('path') module.exports = { build: { env: require('./prod.env'), index: path.resolve(__dirname, '../xxx/index.html'), assetsroot: path.resolve(__dirname, '../xxx'), assetssubdirectory: 'static', assetspublicpath: '/', productionsourcemap: true, productiongzip: false, productiongzipextensions: ['js', 'css'] }, dev: { env: require('./dev.env'), port: 8080, assetssubdirectory: 'static', assetspublicpath: '/', proxytable: { '/api': { target: 'http://www.xxx.com/api.php/', changeorigin: true, pathrewrite: { '^/api': '/' } } }, csssourcemap: false } }
这里target为目标域名,pathrewrite为转换规则,请求数据时将接口地址 根据转换规则请求就可以解决跨域啦!(这里也可以配置headers,设置cookis,token等)
jsonp
jsonp也是一种解决跨域的方法,不过我从来没有用过,在网上查了下资料,jsonp的原理是script标签引入js是不受域名限制的, 由于是模拟插入script标签, 所以不可以用post请求。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
下一篇: 了解VUE的render函数的使用