UniApp本地调试H5跨域问题的解决方法,亲测可用

知识技术 2020-11-19 23:47 3364
转载请务必注明: 来源:《建站管家》https://www.df81.com/news/126.html

UniApp本地调试H5跨域(谷歌chrome浏览器,UniApp内置浏览器不存在此问题)的推荐方案:欺骗浏览器,让浏览器觉得你没有跨域(其实还是跨域了,用的是代理)


客户器端解决方案(亲测可用):

1、在manifest.json里添加如下跨域代码:

"h5" : {
        "devServer" : {
            "port" : 2001,//你H5网址的端口,如:http://localhost:2001/#/pages/index/index
            "disableHostCheck" : true,
            "proxy" : {
                "/api" : {
                    "target" : "http://localhost:2000",//你api接口的请求地址,可以是域名,也可以是本地api地址,也可以是ip地址
                    "changeOrigin" : true,
                    "secure" : false
                }
            },
            "https" : false
        }
    }


2、在你的vue请求页面,如index.vue的代码如下:

uni.request({
    url: '/api/index/index',
    method: 'GET',
    success: (res) => {
        console.log(res);
    }
});


下面这些解释可以不看,照抄上面代码即可

参数说明

"proxy"里的'/api':捕获API的标志,如果API中有这"/api"个字符串,那么就开始匹配代理,

比如API请求"/api/doc/userinfo",会被代理到请求 "https://www.df81.com/api/doc"

即:将匹配到的"/api/doc"替换成"https://www.df81.com/api/doc"

客户端浏览器最终请求链接表面是:"http://127.0.0.1:2001/api/doc/userinfo",

实际上是被代理成了:"http://localhsot:2000/api/doc/userinfo"去向服务器请求数据


target

代理的API地址,就是需要跨域的API地址。

地址可以是域名,如:https://www.df81.com

也可以是IP地址:http://127.0.0.1:2001

如果是域名需要额外添加一个参数changeOrigin: true,否则会代理失败。


pathRewrite

路径重写,也就是说会修改最终请求的API路径。

比如访问的API路径:/api/doc/userinfo,设置pathRewrite: {'^/api' : ''}后

最终代理访问的路径:"https://www.df81.com/doc/userinfo",

将"api"用正则替换成了空字符串,这个参数的目的是给代理命名后,在访问时把命名删除掉。


changeOrigin

这个参数可以让target参数是域名。


secure

secure: false,不检查安全问题。

设置后,可以接受运行在 HTTPS 上,可以使用无效证书的后端服务器


点赞 (0)

收藏 (0)

本站部分信息来源网络,如有侵权,请联系QQ:1062129401删除。

上一篇: 《建站管家》二次开发文档

下一篇: UniApp把数据库里图片相对路径和网址拼接起来的方法

请先登录后,再发表评论 ~ ~
发表评论
发表评论
发表帖子
广告位招租( ¥5 / 天 )
点击咨询
相关帖子

如果要判断文件是否存在,用函数 is_file(),如果要判断目录是否存在,用函数 is_dir()
用宝塔安装TP程序后,网站前台可以访问,后台无法访问,不是程序问题,而是web服务器环境配置问题(PHP配置),出现这种问题,一般是windows主机安装宝塔造成的,linux安装宝塔不会出现此错误
广告位招租( ¥3 / 天 )
点击咨询
广告位招租( ¥2 / 天 )
点击咨询
广告位招租( ¥1 / 天 )
点击咨询
最新帖子

小朋友,你爸爸是谁啊?这很单纯的,就像我们碰到别人会问:你吃过饭了吗?类似;许多人初次相识,经常会问:你是做什么的啊?你做什么,好像决定你收入的高低,你,资产的范围
1、升级框架到ThinkPHP8.0.3【要求PHP8.1+环境,推荐PHP8.1】 2、启用/禁用调试模式等小细节改进
后台点击生成站点地图 一直转圈圈没有反应,
在线客服