问题复现 uniapp项目在浏览器运行,有可能调用某些接口会出现跨域问题,报错如下图所示:

什么是跨域?
存在跨域问题的原因:是,因为浏览器 的 同源策略,也就是说,前端无法直接发起跨域请求。
同源策略是一个基础的安全策略,但是这也会给uniapp/Vue开发者在部署时带来一定的麻烦。
一般来说,浏览器会根据请求来判断是否同源,判断的方式是通过判断两个URL的协议(http or https)、域名和端口是否相同来进行的。
在uniapp中出现跨域问题如何解决?
1.服务端设置CORS
在后端的响应头设置Access-Control-Allow-Origin属性,允许前端的访问:
js
Access-Control-Allow-Origin: *
2.在HBuilder编辑器中使用内置浏览器运行
uniapp项目使用内置浏览器预览调试,可以轻松解决接口在外部浏览器出现的跨域问题。
3.在vite.config.js中配置代理(vue3版本)
js
import { defineConfig } from 'vite';
import uni from '@dcloudio/vite-plugin-uni';
export default defineConfig({
plugins: [uni()],
server: {
host: "localhost", // 指定服务器应该监听哪个IP地址,默认:localhost
port: 5173, // 指定开发服务器端口,默认:5173
proxy: { // 为开发服务器配置自定义代理规则
// 带选项写法:http://localhost:5173/api/posts -> http://jsonplaceholder.typicode.com/posts
"/api": {
target: "http://jsonplaceholder.typicode.com", // 目标接口
changeOrigin: true, // 是否换源
rewrite: (path) => path.replace(/^\/api/, ""),
}
}
}
});
假设接口为http://jsonplaceholder.typicode.com/posts
,那么发送网络请求的时候就可以使用如下方式了:
js
uni.request({
url:"/api/posts" //这里的/api相当于设置的target目标地址
}).then(res=>{
console.log(res);
})
例: 接口地址:https://tiyu.baidu.com/api/match/playerranking/match/NBA/tabId/60
vue.config.js中配置代理(vue2版本)
1)在根目录下创建vue.config.js 2) 拷贝下面的代码
js
module.exports = {
devServer: {
disableHostCheck: true,
proxy: {
"/devapi": {
target: "http://jsonplaceholder.typicode.com",
changeOrigin: true,
secure: false,
pathRewrite: {
"^/devapi": "/"
}
}
}
}
}
- 网络请求应用
js
uni.request({
url:"/devapi/posts" //这里的/devapi相当于设置的target目标地址
}).then(res=>{
console.log(res);
})