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打开,一切运行正常,再也没有上面的跨域问题

相关推荐
糕冷小美n6 小时前
elementuivue2表格不覆盖整个表格添加固定属性
前端·javascript·elementui
小哥不太逍遥6 小时前
Technical Report 2024
java·服务器·前端
沐墨染6 小时前
黑词分析与可疑对话挖掘组件的设计与实现
前端·elementui·数据挖掘·数据分析·vue·visual studio code
anOnion6 小时前
构建无障碍组件之Disclosure Pattern
前端·html·交互设计
threerocks6 小时前
前端将死,Agent 永生
前端·人工智能·ai编程
问道飞鱼7 小时前
【前端知识】Vite用法从入门到实战
前端·vite·项目构建
爱上妖精的尾巴7 小时前
8-10 WPS JSA 正则表达式:贪婪匹配
服务器·前端·javascript·正则表达式·wps·jsa
Aliex_git8 小时前
浏览器 API 兼容性解决方案
前端·笔记·学习
独泪了无痕8 小时前
useStorage:本地数据持久化利器
前端·vue.js
程序员林北北8 小时前
【前端进阶之旅】JavaScript 一些常用的简写技巧
开发语言·前端·javascript