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子应用,再刷新一下页面,报错就消失啦~

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

相关推荐
NiceCloud喜云5 小时前
Opus 4.8 的 Effort Control 怎么选:Low 到 Max 五档策略
android·java·大数据·前端·c++·python·spring
wordbaby6 小时前
React Native + RNOH:跨页面数据回传的最佳实践与避坑指南
前端·react native
丷丩6 小时前
MapLibre GL JS第22课:查看本地GeoJSON
前端·javascript·map·mapbox·maplibre gl js
Front思7 小时前
AI前端工程师需要具备能力+
前端·人工智能·ai
ZC跨境爬虫9 小时前
跟着 MDN 学CSS day_29:(掌握文本与字体样式的核心艺术)
前端·css·ui·html·tensorflow
李子琪。10 小时前
网络空间安全深度实战:CSRF 漏洞原理剖析与基于 Token 的纵深防御体系构建(全栈实验报告)
前端·安全·csrf
冰暮流星10 小时前
javascript之history对象介绍
前端·笔记
IT_陈寒10 小时前
Vite热更新失灵?你可能漏了这个配置
前端·人工智能·后端
丷丩10 小时前
MapLibre GL JS第19课:实时更新要素
前端·javascript·gis·map·mapbox·maplibre gl js
Mr.Daozhi10 小时前
RAG 进阶实战:跑通 Demo 后我连续翻了 6 次车,逐一修复才真正可用(含 Gradio Web 版)
前端·数据库·langchain·大模型·gradio·rag·科研工具