e-header-icon undefined"><img class="icon" src="https://www.notion.so/icons/document_red.svg"/></div><h1 class="page-title"><strong>How SameSite, Same-Origin, and CORS </strong><code><strong>Partially</strong></code><strong> Block XSS and CSRF Attacks</strong></h1><p class="page-description"></p><table class="properties"><tbody><tr class="property-row property-row-created_by"><th><span class="icon property-icon"><svg aria-hidden="true" role="graphics-symbol" viewBox="0 0 16 16" style="width:14px;height:14px;display:block;fill:rgba(55, 53, 47, 0.45);flex-shrink:0" class="typesCreatedBy"><path d="M8 15.126C11.8623 15.126 15.0615 11.9336 15.0615 8.06445C15.0615 4.20215 11.8623 1.00293 7.99316 1.00293C4.13086 1.00293 0.938477 4.20215 0.938477 8.06445C0.938477 11.9336 4.1377 15.126 8 15.126ZM8 10.4229C6.05176 10.4229 4.54785 11.1133 3.83008 11.9131C2.90039 10.9082 2.33301 9.55469 2.33301 8.06445C2.33301 4.91992 4.84863 2.39746 7.99316 2.39746C11.1377 2.39746 13.6738 4.91992 13.6738 8.06445C13.6738 9.55469 13.1064 10.9082 12.1699 11.9131C11.4521 11.1133 9.94824 10.4229 8 10.4229ZM8 9.30176C9.32617 9.30859 10.3516 8.18066 10.3516 6.71094C10.3516 5.33008 9.31934 4.18164 8 4.18164C6.6875 4.18164 5.6416 5.33008 5.64844 6.71094C5.65527 8.18066 6.68066 9.28809 8 9.30176Z"></path></svg></span>Created by</th><td><span class="user"><img src="How%20SameSite,%20Same-Origin,%20and%20CORS%20Partially%20Bloc%201206cd51990d807cad41dc435227707f/IMG_2295.jpg" class="icon user-icon"/>JiaLin Huang</span></td></tr><tr class="property-row property-row-last_edited_time"><th><span class="icon property-icon"><svg aria-hidden="true" role="graphics-symbol" viewBox="0 0 16 16" style="width:14px;height:14px;display:block;fill:rgba(55, 53, 47, 0.45);flex-shrink:0" class="typesCreatedAt"><path d="M8 15.126C11.8623 15.126 15.0615 11.9336 15.0615 8.06445C15.0615 4.20215 11.8623 1.00293 7.99316 1.00293C4.13086 1.00293 0.938477 4.20215 0.938477 8.06445C0.938477 11.9336 4.1377 15.126 8 15.126ZM8 13.7383C4.85547 13.7383 2.33301 11.209 2.33301 8.06445C2.33301 4.91992 4.84863 2.39746 7.99316 2.39746C11.1377 2.39746 13.6738 4.91992 13.6738 8.06445C13.6738 11.209 11.1445 13.7383 8 13.7383ZM4.54102 8.91211H7.99316C8.30078 8.91211 8.54004 8.67285 8.54004 8.37207V3.8877C8.54004 3.58691 8.30078 3.34766 7.99316 3.34766C7.69238 3.34766 7.45312 3.58691 7.45312 3.8877V7.83203H4.54102C4.2334 7.83203 4.00098 8.06445 4.00098 8.37207C4.00098 8.67285 4.2334 8.91211 4.54102 8.91211Z"></path></svg></span>Last edited</th><td><time>@2025年3月30日 15:39</time></td></tr><tr class="property-row property-row-multi_select"><th><span class="icon property-icon"><svg aria-hidden="true" role="graphics-symbol" viewBox="0 0 16 16" style="width:14px;height:14px;display:block;fill:rgba(55, 53, 47, 0.45);flex-shrink:0" class="typesMultipleSelect"><path d="M1.91602 4.83789C2.44238 4.83789 2.87305 4.40723 2.87305 3.87402C2.87305 3.34766 2.44238 2.91699 1.91602 2.91699C1.38281 2.91699 0.952148 3.34766 0.952148 3.87402C0.952148 4.40723 1.38281 4.83789 1.91602 4.83789ZM5.1084 4.52344H14.3984C14.7607 4.52344 15.0479 4.23633 15.0479 3.87402C15.0479 3.51172 14.7607 3.22461 14.3984 3.22461H5.1084C4.74609 3.22461 4.45898 3.51172 4.45898 3.87402C4.45898 4.23633 4.74609 4.52344 5.1084 4.52344ZM1.91602 9.03516C2.44238 9.03516 2.87305 8.60449 2.87305 8.07129C2.87305 7.54492 2.44238 7.11426 1.91602 7.11426C1.38281 7.11426 0.952148 7.54492 0.952148 8.07129C0.952148 8.60449 1.38281 9.03516 1.91602 9.03516ZM5.1084 8.7207H14.3984C14.7607 8.7207 15.0479 8.43359 15.0479 8.07129C15.0479 7.70898 14.7607 7.42188 14.3984 7.42188H5.1084C4.74609 7.42188 4.45898 7.70898 4.45898 8.07129C4.45898 8.43359 4.74609 8.7207 5.1084 8.7207ZM1.91602 13.2324C2.44238 13.2324 2.87305 12.8018 2.87305 12.2686C2.87305 11.7422 2.44238 11.3115 1.91602 11.3115C1.38281 11.3115 0.952148 11.7422 0.952148 12.2686C0.952148 12.8018 1.38281 13.2324 1.91602 13.2324ZM5.1084 12.918H14.3984C14.7607 12.918 15.0479 12.6309 15.0479 12.2686C15.0479 11.9062 14.7607 11.6191 14.3984 11.6191H5.1084C4.74609 11.6191 4.45898 11.9062 4.45898 12.2686C4.45898 12.6309 4.74609 12.918 5.1084 12.918Z"></path></svg></span>Tags</th><td><span class="selected-value select-value-color-default">HTTP</span></td></tr></tbody></table></header><div class="page-body"><p class="">
</p><p class="">
</p><p class="">I’ve read many articles on XSS, CSRF, CORS, and SameSite cookies before, but they were often presented separately, which sometimes left me feeling all mixed up. Therefore, I’ve compiled this overview. </p><p class="">If you don’t have prior knowledge of these topics, you might find this article super confusing LOL, so it’s best to refer to the relevant standalone articles for a clearer understanding.</p><h1 class="">Samesite</h1><p class=""><strong>SameSite decides whether you can bring cookies automatically in cross-site requests.</strong></p><ul class="bulleted-list"><li style="list-style-type:disc"><code><strong>Strict</strong></code>: You ain&#x27;t getting my cookies with CSRF<ul class="bulleted-list"><li style="list-style-type:circle"><code>Set-Cookie: &lt;cK&gt;=&lt;cV&gt;; SameSite=Strict</code></li></ul></li></ul><ul class="bulleted-list"><li style="list-style-type:disc"><code><strong>Lax</strong></code>: You can get cookies under certain conditions<ul class="bulleted-list"><li style="list-style-type:circle"><code>Set-Cookie: &lt;cK&gt;=&lt;cV&gt;; SameSite=Lax</code></li></ul><ul class="bulleted-list"><li style="list-style-type:circle">top-level navigation</li></ul><ul class="bulleted-list"><li style="list-style-type:circle">HTTP GET method. Flip side, <mark class="highlight-red">to avoid CSRF risks with lax, just try to avoid using GET</mark></li></ul></li></ul><ul class="bulleted-list"><li style="list-style-type:disc"><code>None</code>:<ul class="bulleted-list"><li style="list-style-type:circle"><code>Set-Cookie: &lt;cK&gt;=&lt;cV&gt;; SameSite=None; Secure</code></li></ul></li></ul><p class="">
</p><p class="">Limited in preventing XSS, but you can mitigate one XSS method by setting <code>Set-Cookie: &lt;cookieK&gt;=&lt;cookieV&gt;; HttpOnly</code>, as it&#x27;ll stop the browser from reading document.cookies. But this is just for cookies. If they use malicious scripts, you&#x27;ve got way more to worry about.</p><p class="">Keep it simple: can prevent XSS from stealing cookies, but can&#x27;t stop other XSS plays.</p><p class=""><mark class="highlight-blue"><strong>Can greatly prevent CSRF, but only moderately mitigates XSS.</strong></mark></p><h1 class="">Same-Origin Policy</h1><p class="">Cross-origin malicious scripts under SOP can execute, but cannot access cross-origin cookies.</p><p class="">Same-origin malicious scripts can execute and can access same-origin cookies, unless those cookies are marked as HttpOnly.</p><p class="">
</p><p class=""><mark class="highlight-blue"><strong>Can partially prevent XSS but doesn&#x27;t do much like preventing CSRF. CSRF&#x27;s goal is &quot;sending&quot;, not the reading.</strong></mark></p><p class="">
</p><p class="">
</p><h1 class="">Content Security Policy</h1><p class=""><code>Content-Security-Policy: script-src &#x27;self&#x27; https://trustedsite.com;</code></p><p class="">then you can only execute scripts from yours or trustedsite.com’s</p><p class="">
</p><h1 class="">Cross Origin Resource Sharing (CORS)</h1><p class="">Does enabling CORS mitigate XSS or CSRF?</p><h3 class="">CSRF</h3><p class=""><mark class="highlight-red"><strong>Partially</strong></mark>, <mark class="highlight-red">CORS</mark> can just check the origin list (whitelist) if you have the right to go through, but <mark class="highlight-red">cannot check if you&#x27;re... JUST you.</mark></p><p class="">CORS only knows that where you&#x27;re coming from is legitimate, but it doesn&#x27;t mean that someone coming from a certain place is completely harmless.</p><p class="">Also, even if the request does go through (simple request doesn’t need preflight), the CORS can still prevent you from reading the response.</p><h3 class="">XSS</h3><p class="">As for XSS, unless it makes a cross-origin request and gets caught by header checks, XSS itself can&#x27;t be eliminated just because CORS mechanisms exist.</p><p class="">Still, CORS can&#x27;t stop other XSS plays</p><p class="">
</p><p class="">
</p><p class="">
</p><h1 class="">CSRF</h1><p class="">Me, as a Forgery, my main goal is to fake sending requests, not reading your secrets. So, I don’t care about your Same-Origin Policy.</p><h2 class="">How to fight with CSRF?</h2><ol type="1" class="numbered-list" start="1"><li>backend generates a csrf token and frontend keep it.</li></ol><ol type="1" class="numbered-list" start="2"><li>backend sets sameSite cookie policy, and frontend (as browser) apply it.</li></ol><ol type="1" class="numbered-list" start="3"><li>origin? referer (longer than origin)?</li></ol><ol type="1" class="numbered-list" start="4"><li>etc</li></ol><p class="">
</p><p class="">
</p><h1 class="">XSS</h1><p class="">Well, if you don&#x27;t have XSS defense mechanisms and an XSS script succeeds, it can execute CSRF, and even sniff out CSRF-related checks like origin, referer, and even csrf token. Then you&#x27;re screwed.</p><p class="">
</p><p class="">
</p><h1 class="">Thoughts</h1><p class="">Prioritize solving XSS, otherwise even amount of CSRF checking methods will do no good.</p><p class="">But actually, since JWT tokens are commonly used now, there’s not much need to worry about cookies if the frontend and backend communicate with tokens.</p><p class="">
</p><p class="">
</p><h1 class="">Table</h1><table class="simple-table"><tbody><tr><td class="" style="width:192.66666666666666px"><strong>mechanism</strong></td><td class="" style="width:217.6640625px"><strong>fight XSS?</strong></td><td class="" style="width:192.66666666666666px"><strong>fight CSRF?</strong></td></tr><tr><td class="" style="width:192.66666666666666px"><strong>Set-Cookie: …;SameSite={Lax,Strict}</strong></td><td class="" style="width:217.6640625px">prevent XSS getting cookies, but cannot stop XSS</td><td class="" style="width:192.66666666666666px">Mostly ⭕</td></tr><tr><td class="" style="width:192.66666666666666px"><strong>Same Origin Policy (browser’s built-in mechanism)</strong></td><td class="" style="width:217.6640625px"><mark class="highlight-blue">tell browser to execute scripts from whitelist </mark>⭕</td><td class="" style="width:192.66666666666666px">-</td></tr><tr><td class="" style="width:192.66666666666666px"><strong>CSP (Content Security Policy)</strong></td><td class="" style="width:217.6640625px">using origin whitelist to preventing XSS execution <mark class="highlight-blue"> </mark>⭕</td><td class="" style="width:192.66666666666666px">-</td></tr><tr><td class="" style="width:192.66666666666666px"><strong>Set-Cookie: ...; HttpOnly</strong></td><td class="" style="width:217.6640625px">prevent XSS getting cookies ⭕</td><td class="" style="width:192.66666666666666px">nothing to stop CSRF from using cookies</td></tr><tr><td class="" style="width:192.66666666666666px"><strong>CSRF Tokens</strong></td><td class="" style="width:217.6640625px">-</td><td class="" style="width:192.66666666666666px">Mostly ⭕ <mark class="highlight-yellow_background">[tag1]</mark></td></tr></tbody></table><p class=""><mark class="highlight-yellow_background">tag1</mark></p><p class="">If the website does not have XSS protection, an attacker can steal the CSRF token through an XSS attack, thereby bypassing the CSRF protection mechanism.</p><p class="">
</p></div></article><span class="sans" style="font-size:14px;padding-top:2em"></span></body>