一个关于axios跨协议请求的问题

发布于 2022-09-07 16:36:58 字数 1001 浏览 13 评论 0

项目使用的是vue-cli全家桶,异步请求用的axios,由于项目刚刚从http升级到https,所以测试了一下接口访问有没有问题,发现莫名其妙出现了一个问题:
请求的url前面会自己带上一个本地的域名(这是本地调试,如果是线上调试就会带上对应的线上域名),这是为什么?

clipboard.png

我在config/index.js文件里面配置了如下转换

dev: {
    env: require('./dev.env'),
    port: 8082,
    autoOpenBrowser: true,
    assetsSubDirectory: 'static',
    assetsPublicPath: '/',
    proxyTable: {
        '/apis':{
            target:'http//api.open.test.ai',
            changeOrigin:true,
            pathRewrite:{
                '^/apis':'/apis'
            }
        }
    }
}

然后请求是这样发的:

this.$axios.post('/apis/readingcutupload', {
    file: data
}).then(res => {
    if (res.data.result === 1) {
        t.success('上传成功!');
    } else {
        t.error(res.data.msg);
    }
})

但是为啥控制台上看请求是这样的呢》:好像并没有被转换

clipboard.png

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

白首有我共你 2022-09-14 16:36:58

默认是个相对路径,比如axios.get('/api/login')。既然你用了vue-cli,建议配置下proxyTable,做个代理转发,在文件config/index.js里设置。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文