microApp 子应用跨域问题

最近在尝试微前端的方式实现新系统和老系统页面的兼容,目前市面上活跃度比较高的微前端技术:qiankun、microapp、wujie。经过对各大官网以及github的研究,个人首先pass掉qiankun,因为本来就对微前端不熟悉的我来说,qiankun的官网简单到让我无处下手。wujie和microapp的官网很友好,讲得很详细。但考虑到怕后期遇到问题,不知道如何处理的情况,避免少踩坑,最终还是选择了比较成熟的microapp。

背景: 主应用:vite+vue3 子应用:vue2+webpack

问题:子应用成功在主应用中显示,但是子应用中的数据接口请求时(单独启动子应用,接口调用是正常的),报了跨域问题

官网针对于跨域有相应的处理方法:

奈何我已经在子应用中设置了,问题仍然存在。百度了很多博客,也看了github上的issue,都没能解决。最后请教了一下外援(团队中的技术骨干),我花了一上午都没解决的,人家几分钟就给我解决了。(没有对比就没有伤害呀~呜呜)

问题解决: 报错中提示的意思,除了跨域问题外,还明确表示Access-Control-Allow-Headers需要配置token(我当时就没看出来,喵了一眼,脑袋中就认定是Access-Control-Allow-Origin的配置问题)

后面修改配置,添加了Access-Control-Allow-Headers

css 复制代码
headers:{
      'Access-Control-Allow-Origin': '*',
      'Access-Control-Allow-Headers': 'DNT,X-Mx-ReqToken,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Authorization,token'
    }

重新启动webpack子应用,再刷新一下页面,报错就消失啦~

记录原因:网上记录类似错误的博客很少,特此记录,复盘的同时也希望大家作为参考,避免踩坑~

相关推荐
前端 贾公子3 分钟前
release-it 使用指南
前端·javascript
全栈技术负责人36 分钟前
前端团队 AI Core Workflow:从心法到落地
前端·人工智能·状态模式
前端 贾公子1 小时前
深入浅出 CSS 属性:pointer-events: none
前端·css
曾几何时`1 小时前
二分查找(十)1146. 快照数组 pair整理
java·服务器·前端
夏河始溢1 小时前
一八二、webpack、grunt、gulp、rollup、parcel、vite 对比介绍
前端·webpack·gulp
别或许2 小时前
python中的异步调用(直接使用教程)
java·前端·python
xkxnq2 小时前
第四阶段:Vue 进阶与生态整合(第 47 天)(Vue 项目目录结构解析:每个文件夹的作用与规范)
前端·javascript·vue.js
炽烈小老头2 小时前
浏览器渲染原理:从 HTML 到像素的全链路拆解
前端
打小就很皮...2 小时前
React 合同审查组件:按合同原文定位
前端·react.js·markdown
EndingCoder2 小时前
设计模式在 TypeScript 中的实现
前端·typescript