日本家居服飾品牌gelato pique與《集合啦!動物森友會》推出一系列超可愛聯名家居服!   刺客教條最新作《刺客教條:維京紀元》全球首發電影式預告   『仁王2』第二波付費DLC「平安京討魔傳」開放下載! 史上最強的討魔武者‧源賴光,及史上最強的陰陽師‧安倍晴明隆重登場!   Riot Games宣布《VALORANT特戰英豪》正式上市6月2日全球同步發行   ASUS推出新款電競耳麥「ROG Theta Electret」!5/31前購入隨貨贈送「ROG Throne RGB耳機架」   侍魂 SAMURAI SPIRITS推出Xbox Series X / S版   即將上市!人氣話題超級大作《電馭叛客2077》官方長篇預告公開!   「鬼滅之刃」和「他媽哥池」合作!「鬼滅他媽哥池」將於2020年10月登場! 

PHP Cookie SameSite 的設定方式

商業

Chrome 80 之後的版本,預設的 Cookie 設定將會無法跨站存取 Cookie 值,若想要允許 Cookie 跨網站存取的話(SameSite = None),需要使用 HTTPS 才可以。

  • 註:SameSite 用來阻止瀏覽器將 Cookies 跨網站發送 (prevents the browser from sending this cookie along with cross-site requests)

PHP Cookie SameSite 的設定方式

Chrome 80 之後的 Cookie SameSite 設定有三種(預設改為 Lax):

  • Strict
  • Lax (default)
  • None (需有 HTTPS 搭配,否則一樣等同 Lax)

Cookie SameSite 官方文件

Cookie SameSite 跨網域存取

  • SameSite=Strict:最嚴謹,只有與目前網頁網址一致才能發送 (remote.example、site.example 互相無法發送)
    • Set-Cookie: CookieName=CookieValue; SameSite=Strict;
  • SameSite=Lax:使用 GET remote.example 向 site.example 發送,Cookie 將會送向 remote.example (POST 則不會發送 Cookie)
    • Set-Cookie: CookieName=CookieValue; SameSite=Lax;
  • SameSite=None + HTTPS:允許跨網域存取,但是若沒 HTTPS 則預設「拒絕」跨網域存取
    • 無效:Set-Cookie: remote_session=abc123; SameSite=None
    • 有效:Set-Cookie: remote_session=abc123; SameSite=None; Secure

而 SameSite 的設定,於 PHP 7.2 以前尚未支援,所以 PHP 7.2 以前和 PHP 7.3 寫法不同:

PHP 7.2 以前的 SameStie Cookie 寫法

  • header('Set-Cookie: cross-site-cookie=name; SameSite=None; Secure');

PHP 7.3 以後的 SameStie Cookie 寫法

  • setcookie('cross-site-cookie', 'name', ['samesite' => 'None', 'secure' => true]);

相關網頁

Tsung
PureVPN

隨機商業新聞