91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

php如何實現響應頭增加token

發布時間:2023-02-20 14:12:45 來源:億速云 閱讀:143 作者:iii 欄目:編程語言

這篇文章主要介紹“php如何實現響應頭增加token”,在日常操作中,相信很多人在php如何實現響應頭增加token問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”php如何實現響應頭增加token”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

php實現響應頭增加token的方法:1、在請求的header頭中的Authorization字段使用Bearer模式添加JWT;2、在服務器收到請求后,使用JWT規范,進行生成token,返回給客戶端即可。

php token的生成和使用

1. 為什么要使用tokent進行登錄

前后端分離或者為了支持多個web應用,那么原來的cookies或者session在使用上就會有很大的問題

cookie和session認證需要在同一主域名下才可以進行認證(目前可以把session存儲在redis內進行解決)。

2. 解決方案

oauth3 和 jwt

jwt :是一種安全標準。基本思路就是用戶提供用戶名和密碼給認證服務器,服務器驗證用戶提交信息信息的合法性;如果驗證成功,會產生并返回一個token(令牌)

OAuth3 :是一個安全的授權框架。它詳細描述了系統中不同角色、用戶、服務前端應用(比如API),以及客戶端(比如網站或移動APP)之間怎么實現相互認證。

(這里采用jwt,這種JSON Web Token 這種方式進行認證)

3. 生成方法

頭部:加密類型

說明:消息內容

key:一個隨機碼用來加密

上面三部分使用.連接起來,然后使用hs256進行加密,生成tokent

4. 詳細生成方法

1). 頭部通常由兩部分組成:令牌的類型(即JWT)和所使用的加密算法(如:SHA256或者RSA)

{
      "alg": "HS256",
      "typ": "JWT"
}

然后,這個json被Base64Url編碼,成為第一部分

2). 有效載荷是聲明。聲明是關于實體的部分。

{
      "exp": "1525785339",
      "sub": "1234567890",
      "name": "John Doe",
      "admin": true
}

然后將有效載荷Base64Url進行編碼,成為第二部分

(PS:此信息盡管受到篡改保護,但是任何人都可以閱讀。除非加密,否則不要將重要信息放在里面)

3). 使用一個加密key

4). 簽名,需要使用編碼后的第一部分,編碼后的第二部分,然后一個關鍵的key。采用第一部分里的加密算法進行簽名

HMACSHA256(
          base64UrlEncode(header) + "." + base64UrlEncode(payload),
          key
)

該簽名用于驗證消息是否有篡改。

(PHP使用crypt方法進行加密。注意:SHA-256用于防篡改,AES-256用于加密兩個概念不一樣)

5. token存放位置

通常應該在請求的header頭中的 Authorization字段使用 Bearer模式添加JWT(Authorization: Bearer ) (當然你也可以放在任意位置,如URL后面當成一個參數傳遞,只要客戶端能識別就行,不過既然JWT是個規范,那么我們最好還是按照規范來)

6. 使用方式

客戶端用戶輸入用戶名密碼后執行登錄,請求token

服務器收到請求后,使用JWT這種規范,進行生成token,返回給客戶端

客戶端收到token以后,解密后,驗證token的時效性(token的過期時間),保存起來

客戶端拿token請求數據

服務器收到token解密后,驗證用戶身份,驗證時效性,然后驗證用戶

7. 缺點

1. 無法作廢已頒布的令牌(對token刷新使用期限)

2. 不易應對過期數據(支持 token 失效)

所以如果你使用了 token ,那么如果 token 被捕獲到,那么就可以進行偽造進行冒充。所以如果安全比較高的話,還是建議使用oauth3。

到此,關于“php如何實現響應頭增加token”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

扶沟县| 家居| 蒙城县| 治县。| 宁陕县| 湟源县| 浦县| 永清县| 石柱| 扶风县| 灵川县| 黑河市| 西城区| 田林县| 抚顺县| 丹巴县| 安西县| 普兰店市| 于都县| 灵台县| 尚志市| 罗定市| 咸阳市| 桃园市| 都安| 宣武区| 扬中市| 鹤岗市| 宝坻区| 普定县| 陆河县| 色达县| 泽州县| 涞源县| 三亚市| 花垣县| 呼伦贝尔市| 普兰店市| 红原县| 尤溪县| 盐亭县|