原来 CORS 并不会阻止一个请求被发送,而只是阻止前端读取 Response - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
fancy2020

原来 CORS 并不会阻止一个请求被发送,而只是阻止前端读取 Response

  •  
  •   fancy2020 Nov 8, 2023 2953 views
    This topic created in 904 days ago, the information mentioned may be changed or developed.

    之前一直以为设置了 CORS ,那么 Allowed Origin 之外的其他域名下的代码发送的请求就不会到达服务端。

    今天凑巧研究了一下 CSRF 的攻击过程,原来设置了 CORS 只会阻止前端代码读取 Response 的内容,但这个请求本身还是会被发送到服务端,并被处理。

    11 replies    2023-11-08 19:47:30 +08:00
    Meiyun
        1
    Meiyun  
       Nov 8, 2023
    不发送到服务端前端怎么知道有没有被允许?
    proxytoworld
        2
    proxytoworld  
       Nov 8, 2023
    你是不是搞错了 cors 防 xss 的,csrf 防护对应的是 csrf token
    jiangzm
        3
    jiangzm  
       Nov 8, 2023
    无知了哈,
    OPTIONS 请求不会阻止
    GET/POST 请求会阻止
    yumusb
        4
    yumusb  
       Nov 8, 2023
    option 预检请求会被发送。
    jiangzm
        5
    jiangzm  
       Nov 8, 2023   1
    即使 OPTIONS 返回了内容也会忽略。
    大概率你的服务端没有按标准 CORS 输出内容
    retanoj
        6
    retanoj  
       Nov 8, 2023
    所以你知道了 Access-Control-Allow-Origin 这个 header 头是服务端设置并返回的对吧。
    事实上,为了解决 XS-*类的问题,还有其他很多机制是浏览器配合服务端一起实现的。
    比如 Fetch Metadata/ COOP / CORP
    limaofeng
        7
    limaofeng  
       Nov 8, 2023 via iPhone
    一般情况下,httpserver 都不会拒绝客户端发送的请求。 那是防火墙的工作
    AV1
        8
    AV1  
       Nov 8, 2023 via Android
    HTTP 报头的 referer 和 origin ,就是用来给服务端检查请求来源的。但估计大部分服务端开发都没这个意识,都是全盘放行。
    ETiV
        9
    ETiV  
       Nov 8, 2023 via iPhone
    恭喜你学到了新知识
    we21x
        10
    we21x  
       Nov 8, 2023
    这个我记得是分 简单请求 和 非简单请求,简单请求的响应跨域了话会被拦截,非简单请求预检过不了所以不会发送实际的请求。

    *区分简单请求和非简单请求:请求方法 和 content-type
    fancy2020
        11
    fancy2020  
    OP
       Nov 8, 2023
    @jiangzm

    之前的确无知了,让您见笑了
    About     Help     Advertise     Blog     API     FAQ     Solana     2771 Online   Highest 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 52ms UTC 13:54 PVG 21:54 LAX 06:54 JFK 09:54
    Do have faith in what you're doing.
    ubao msn 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