关于跨域种 cookie 问题求问 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
请不要在回答技术问题时复制粘贴 AI 生成的内容
beihu
V2EX    程序员

关于跨域种 cookie 问题求问

  •  
  •   beihu 310 天前 1739 次点击
    这是一个创建于 310 天前的主题,其中的信息可能已经有所发展或是发生改变。

    目前项目内通过 iframe 内嵌一个三方的页面 三方页面内的接口如果要正常调用的话需要获取本地 cookie 里的有效 token 才能正常调用接口 目前三方页面提供了一个获取 token 的接口 需要在 A 页面调用然后接口直接在 cookie 里种 domain 为三方页面域名的 token 现在的问题在 A 页面调用之后无法成功种 token 请问这种思路有没有问题 有什么方案能解决这种需求呢(三方页面不改动的情况下)

    14 条回复    2024-12-06 15:14:37 +08:00
    xuanbg
        1
    xuanbg  
       310 天前
    我无法理解你要如何给 iframe 内嵌一个三方的页面灌一个 cookie 进去。不应该由第三方页面自己在 iframe 里面实现登录和跳转吗?
    ltaoo1o
        2
    ltaoo1o  
       310 天前
    同一个域名还有可能,两个完全没关联的网站不可能做到。

    正常做法都是嵌入三方页面时,链接上会带授权信息,三方页面从链接上取授权信息。
    yinmin
        3
    yinmin  
       310 天前 via iPhone
    试试将写 cookie 的 js 代码注入到 iframe 第三方网页里
    rowink
        4
    rowink  
       310 天前 via Android
    如果 iframe 的页面不能给注入 js ,那没什么办法。估计也只有配合浏览器插件能够做到,这个需求基本上就维持 iframe 界面的 token 持久化,浏览器插件就没有跨域之分了,但是这就是另一个问题了
    doommm
        5
    doommm  
       310 天前
    iframe 内的网页是不是可以接受外部发过来的事件?
    doommm
        6
    doommm  
       310 天前
    magicflower
        7
    magicflower  
       309 天前 via Android
    第三方服务端配置 SameSite 。
    alwaysol
        8
    alwaysol  
       309 天前
    Nginx 反代理,把第三方网页地址反代理成你的网页域名就可以共享 cookie
    dingxi
        9
    dingxi  
       309 天前
    7L + 8L 可以试试, 以谷歌浏览器为例,不仅是服务端需要设置 SameSite ,浏览自带的安全限制也有 SameSite ,低版本可以直接修改为级别低,这样非同源的内嵌 iframe 的请求也会携带 cookie ,高版本不让修改。
    同理 8L 也是为了伪装同源,让内嵌 iframe 绕过浏览器的 SameSite 限制
    fengpan567
        10
    fengpan567  
       309 天前
    无解了,换成 oauth 2.0 ,走 url 跳转吧
    skallz
        11
    skallz  
       309 天前
    @ltaoo1o 别说,以前还真接过类似的需求,不过两个域名都是可以使用的,方法是当一个域名页面登录后,获取该页面的 token 和 ip 和浏览器指纹,然后另一个域名网页登录后会检查是否有同 ip 与同浏览器指纹的数据,并且该数据更新时间需小于一定的时间间隔,如果有,则自动获取 token 进行登录
    skallz
        12
    skallz  
       309 天前
    @skallz 说错,不是另一个网页登录,是另一个网页进入后
    ltaoo1o
        13
    ltaoo1o  
       309 天前
    @skallz 理解,不过这个逻辑依赖后端保存「同浏览器指纹的数据」吧,A 域登录获取 token ,B 域要如何「检查」呢
    skallz
        14
    skallz  
       309 天前
    @ltaoo1o B 域页面进入后发起请求,带上浏览器指纹和 ip ,服务端查询,有符合条件的则返回 token ,B 域网页再拿到 token 进入登录状态
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     886 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 24ms UTC 22:27 PVG 06:27 LAX 15:27 JFK 18:27
    Do have faith in what you're doing.
    ubao snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86