跨境派

跨境派

跨境派,专注跨境行业新闻资讯、跨境电商知识分享!

当前位置:首页 > 卖家故事 > UniApp H5 跨域代理配置并使用(配置manifest.json、vue.config.js)

UniApp H5 跨域代理配置并使用(配置manifest.json、vue.config.js)

时间:2024-04-06 18:45:29 来源:网络cs 作者:康由 栏目:卖家故事 阅读:

标签: 配置  使用  代理 
阅读本书更多章节>>>>

UniApp 运行到浏览器的时候,接口会跨域报错,这里通过两种方式解决,第一:修改Uniapp自带的manifest.json 源码视图并进行配置h5设置。第二:在项目根目录新建vue.config.js并配置代理。 二选一即可。

修改或调整配置文件后,推荐重新运行,以防不生效。

配置完成后,请求接口显示 Please enable JavaScript to continue. 的话,可以试试重启编辑器(尤其是 HBuilderX),再重新运行项目,如果还是不行就另外查查解决方案吧,网上有很多。

一、方式一:修改 manifest.json 文件

在 UniApp 也有类似配置的地方:找到 manifest.json -》源码视图,添加 h5 配置项:

"h5" : {    "devServer" : {        "disableHostCheck" : true,        "proxy" : {            "/api" : {                "target" : "http://www.dzm.com",                "changeOrigin" : true,                "secure" : false,                "ws": false,                "pathRewrite" : {                    "^/api" : ""                }            }        }    }}

在这里插入图片描述

二、方式二:添加 vue.config.js 文件

UniApp 会识别 vue.config.js 文件,但是 manifest.json 的优先级
要高于 vue.config.js 文件,所以看需求选择一个配置即可。

像 vue 开发一样,手动创建一个 vue.config.js 文件,然后添加上代理,vue.config.js 只能创建在项目的根目录,不然会无法识别到。

module.exports = {    devServer: {        disableHostCheck: true,        proxy: {            '/api': {                target: 'http://www.dzm.com',                changeOrigin: true,                secure: false,                ws: false,                pathRewrite: {                    '^/api': ''                }            }        }    }}

三、使用

简单使用

// 请求对象uni.request({    url: '/api' + '/mobile/user/userinfo',    method: 'GET',    data: {},    header: {        'X-Token': uni.getStorageSync('token')    },    success: (res) => {        // 请求成功        console.log(res)    },    fail: (err) => {        // 请求失败        console.log(err)    }})

封装成请求对象 request.js

// 接口域名// #ifdef H5const BaseHost = '/api'// #endif// #ifndef H5const BaseHost = 'http://www.dzm.com'// #endif// 请求封装export default function ({    // 请求域名    host = BaseHost,    // 请求地址    url,    // 请求方式    method,    // 请求数据    data = {},    // 请求头    header = {}}) {    // 官方请求文档(可查阅传参)https://uniapp.dcloud.io/api/request/request.html    // 转为 Promise 结构    return new Promise((resolve, reject) => {        // 请求对象        uni.request({            url: host + url,            method,            data,            header: Object.assign({                // 默认请求头                'X-Token': uni.getStorageSync('token')            }, header),            success: (res) => {                // 可以在这里进行成功的公共处理                resolve(res)            },            fail: (err) => {                // 可以在这里进行失败的公共处理                reject(err)            }        })    })}
阅读本书更多章节>>>>

本文链接:https://www.kjpai.cn/gushi/2024-04-06/154929.html,文章来源:网络cs,作者:康由,版权归作者所有,如需转载请注明来源和作者,否则将追究法律责任!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。

文章评论