uniApp h5解决Chrome跨域问题的最终方法

最近用Dcloud 工具 HBuilder X写了一个uniapp 客户端项目,代码在HBuilder 工具内运行没有问题, 打包后放在android app 和ios app内运行也没有问题,唯有把h5链接地址放在chrome里会有如下跨域问题:

Access to XMLHttpRequest at 'https://www.yachen.com/api/auth/sendinfo' from origin 'http://localhost:8080' has been blocked by CORS policy: Response to preflight request doesn't pass access control check: No 'Access-Control-Allow-Origin' header is present on the requested resource.

跨域是浏览器的专用概念,指js代码访问自己来源站点之外的站点。比如A站点网页中的js代码,请求了B站点的数据,就是跨域。

A和B要想被认为是同域,则必须有相同的协议(比如http和https就不行)、相同域名、和相同端口号(port)。

如果你是做App、小程序等非H5平台,是不涉及跨域问题的。而Hbuilder 内置浏览器把检查跨域那部分屏蔽,所以在内部web运行时也不存在跨域问题。

关于这个跨域问题,网上有两种解决方法:

  1. 给Chrome 安装插件Allow CORS: Access-Control-Allow-Origin ,网上有很多安装示例,无奈我尝试了半天,插件也安装了,错误照旧,不知道哪里出问题了;
  2. 这种方法是给项目代码加代理,在根目录下添加配置文件vue.config.js, 按照网上的方法一步一步配置,仍然不行,后来把vue.config.js 改为vue.config.json 反而可以了。

配置代码如下

module.exports = {

publicPath: './h5',

devServer: {

proxy: {

'/woch': {

target: 'https://www.yachen.com',

ws: true,

changeOrigin: true,

pathRewrite: {

'^/woch': ''

}

}

}

},

}

代码里的绝对url路径改为相对路径,譬如以前有问题的代码

uni.request({

url: ' https://www.yachen.com/api/sendinfo', //仅为示例,并非真实接口地址。

data: {//参数

......

},

header: {

......

},

method:'POST',//请求方式 或GET,必须为大写

});

将里面的url

url: ' https://www.yachen.com/api/sendinfo ',

改为

url: 'woch/api/sendinfo',

这样所有url绝对路径都改完后,加上根目录的配置文件 vue.config.json,再次编译生成的链接地址在Chrome打开,一切运行正常,再也没有上面的跨域问题

相关推荐
QQ1__8115175151 小时前
Spring boot名城小区物业管理系统信息管理系统源码-SpringBoot后端+Vue前端+MySQL【可直接运行】
前端·vue.js·spring boot
John_ToDebug1 小时前
深入剖析 WebHostView:浏览器内核中的桌面级 Web 宿主
chrome
钛态1 小时前
前端微前端架构:大项目的救命稻草还是自找麻烦?
前端·vue·react·web
一粒黑子1 小时前
【实战解析】阿里开源 PageAgent:纯前端 GUI Agent,一行JS让网页支持自然语言操控
前端·javascript·开源
独角鲸网络安全实验室1 小时前
2026微信小程序抓包全解析:从实操落地到合规风控,解锁前端调试新范式
前端·微信小程序·小程序·抓包·系统代理绕过·https证书严格校验·进程隔离
紫微AI1 小时前
前端文本测量成了卡死一切创新的最后瓶颈,pretext实现突破了
前端·人工智能·typescript
GISer_Jing1 小时前
AI前端(From豆包)
前端·aigc·ai编程
IT枫斗者1 小时前
前端部署后如何判断“页面是不是最新”?一套可落地的版本检测方案(适配 Vite/Vue/React/任意 SPA)
前端·javascript·vue.js·react.js·架构·bug
测试修炼手册1 小时前
[测试技术] 深入理解 JSON Web Token (JWT)
前端·json
AI老李1 小时前
2026 年 Web 前端开发的 8 个趋势!
前端