




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
第Go語言如何使用golang目錄前言1.什么是JWT2.JWT的數(shù)據(jù)結(jié)構(gòu)2.1Header2.2Payload2.3Signature2.4Base64URL3使用JWT安裝生成Token總結(jié)
前言
最近寫的項目中用到了JWT鑒權(quán),因此做個記錄
原先的jwt-go倉庫已經(jīng)不再維護(hù),遷移到了/golang-jwt/jwt/v4
但是網(wǎng)上大多數(shù)還是v3版本的使用教程,建議使用更加安全的v4
1.什么是JWT
JSONWebToken(JWT)是一個開放標(biāo)準(zhǔn)(RFC7519),它定義了一種緊湊的、自包含的方式,用于作為JSON對象在各方之間安全地傳輸信息。特別適用于分布式站點的單點登錄(SSO)場景。JWT的聲明一般被用來在身份提供者和服務(wù)提供者間傳遞被認(rèn)證的用戶身份信息,以便于從資源服務(wù)器獲取資源,也可以增加一些額外的其它業(yè)務(wù)邏輯所必須的聲明信息,該token也可直接被用于認(rèn)證,也可被加密。
2.JWT的數(shù)據(jù)結(jié)構(gòu)
實際的JWT由三部分組成,如下圖
中間用點(.)分隔成三個部分。注意,JWT內(nèi)部是沒有換行的,這里只是為了便于展示,將它寫成了幾行。JWT的三個部分依次如下:
Header(頭部)Payload(負(fù)載)Signature(簽名)
寫成一行就是Header.Payload.Signature
2.1Header
Header部分是一個JSON對象,描述JWT的元數(shù)據(jù),通常是下面的樣子
{
"alg":"HS256",
"typ":"JWT"
上面代碼中,alg屬性表示簽名的算法(algorithm),默認(rèn)是HMACSHA256(寫成HS256);typ屬性表示這個令牌(token)的類型(type),JWT令牌統(tǒng)一寫為JWT。
將上面的JSON對象使用Base64URL算法(詳見后文)轉(zhuǎn)成字符串就成了第一部分Header。
2.2Payload
Payload部分也是一個JSON對象,用來存放實際需要傳遞的數(shù)據(jù)。JWT規(guī)定了7個官方字段,供選用。
iss(issuer):簽發(fā)人exp(expirationtime):過期時間sub(subject):主題aud(audience):受眾nbf(NotBefore):生效時間iat(IssuedAt):簽發(fā)時間jti(JWTID):編號
我們還可以在這個部分自己定義字段,下面就是一個例子
{
"sub":"1234567890",
"name":"JohnDoe",
"admin":true
注意,JWT默認(rèn)是不加密的,任何人都可以讀到,所以不要把秘密信息放在這個部分。
這個JSON對象也要使用Base64URL算法轉(zhuǎn)成字符串。
2.3Signature
Signature部分是對前兩部分的簽名,防止數(shù)據(jù)篡改。
首先,需要指定一個密鑰(secret)。這個密鑰只有服務(wù)器才知道,不能泄露給用戶。然后,使用Header里面指定的簽名算法(默認(rèn)是HMACSHA256),按照下面的公式產(chǎn)生簽名。
HMACSHA256(
base64UrlEncode(header)+"."+
base64UrlEncode(payload),
secret)
2.4Base64URL
前面提到,Header和Payload串型化的算法是Base64URL。這個算法跟Base64算法基本類似,但有一些小的不同。
JWT作為一個令牌(token),有些場合可能會放到URL(比如/token=xxx)。Base64有三個字符+,/和=,在URL里面有特殊含義,所以要被替換掉:=被省略、+替換成-,/替換成_。這就是Base64URL算法。
算出簽名以后,把Header、Payload、Signature三個部分拼成一個字符串,每個部分之間用點(.)分隔,就可以返回給用戶。
3使用JWT
安裝
goinstall"/golang-jwt/jwt/v4"
生成Token
定義claims和serect
typeMyClaimsstruct{
Phonestring`json:"phone"`
jwt.RegisteredClaims//注意!這是jwt-go的v4版本新增的,原先是jwt.StandardClaims
varMySecret=[]byte("手寫的從前")//定義secret,后面會用到
生成token
//這里傳入的是手機(jī)號,因為我項目登陸用的是手機(jī)號和密碼
funcMakeToken(phonestring)(tokenStringstring,errerror){
claim:=MyClaims{
Phone:phone,
RegisteredClaims:jwt.RegisteredClaims{
ExpiresAt:jwt.NewNumericDate(time.Now().Add(3*time.Hour*time.Duration(1))),//過期時間3小時
IssuedAt:jwt.NewNumericDate(time.Now()),//簽發(fā)時間
NotBefore:jwt.NewNumericDate(time.Now()),//生效時間
token:=jwt.NewWithClaims(jwt.SigningMethodHS256,claim)//使用HS256算法
tokenString,err=token.SignedString(MySecret)
returntokenString,err
解析token
funcSecret()jwt.Keyfunc{
returnfunc(token*jwt.Token)(interface{},error){
return[]byte("手寫的從前"),nil//這是我的secret
funcParseToken(tokenssstring)(*MyClaims,error){
token,err:=jwt.ParseWithClaims(tokenss,MyClaims{},Secret())
iferr!=nil{
ifve,ok:=err.(*jwt.ValidationError);ok{
ifve.Errorsjwt.ValidationErrorMalformed!=0{
returnnil,errors.New("that'snotevenatoken")
}elseifve.Errorsjwt.ValidationErrorExpired!=0{
returnnil,errors.New("tokenisexpired")
}elseifve.Errorsjwt.ValidationErrorNotValidYet!=0{
returnnil,errors.New("tokennotactiveyet")
}else{
returnnil,errors.New("couldn'thandlethistoken")
ifcl
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 精益管理與企業(yè)制度的整合創(chuàng)新
- 機(jī)電工程考試規(guī)劃與試題及答案
- 西方政治制度的公共政策導(dǎo)向試題及答案
- 物聯(lián)網(wǎng)技術(shù)在網(wǎng)絡(luò)中的應(yīng)用試題及答案
- 公共政策與生態(tài)環(huán)境的相互影響試題及答案
- 網(wǎng)絡(luò)工程師考試基礎(chǔ)試題及答案
- 信息系統(tǒng)項目管理師課題研究試題及答案
- 掌握機(jī)電工程核心考點試題及答案2025
- 教育公平與公共政策的協(xié)調(diào)與優(yōu)化試題及答案
- 民間公益組織與政策倡導(dǎo)的互動關(guān)系試題及答案
- 2025工程建設(shè)項目多測合一成果報告書范本
- 麻醉科麻精藥品PDCA管理
- 兒童發(fā)展問題的咨詢與輔導(dǎo)-案例1-5-國開-參考資料
- 2025年河北石家莊市市屬國有企業(yè)招聘筆試參考題庫含答案解析
- 2025年度安徽白帝集團(tuán)限公司社會招聘高頻重點提升(共500題)附帶答案詳解
- 公益招貼設(shè)計課件
- 靜脈治療小組開展工作匯報
- (優(yōu)化版)高中地理新課程標(biāo)準(zhǔn)【2024年修訂版】
- 國家電網(wǎng)公司招聘高校畢業(yè)生應(yīng)聘登記表
- 2024年重慶市中考化學(xué)試題(A卷)含答案
- 全國數(shù)據(jù)應(yīng)用大賽“數(shù)字安全賽”備賽試題及答案
評論
0/150
提交評論