go語(yǔ)言使用jwt認(rèn)證的實(shí)現(xiàn)
這幾天在學(xué)習(xí)nodejs,進(jìn)一步了解npm,學(xué)習(xí)過(guò)程中解開了以前的一個(gè)疑惑,以前不知道token可以攜帶信息,只以為是用來(lái)做對(duì)比的,學(xué)到了jwt身份認(rèn)證,知道了如何使用的,感覺很好用,但是我不用nodejs開發(fā),所以就去看了下golang的,做下記錄
剛學(xué),博客內(nèi)容寫的可能不大對(duì),因?yàn)榛径际亲约旱睦斫?,術(shù)語(yǔ)用的可能也不到位,但是用起來(lái)倒是沒問(wèn)題,見諒
golang-jwt 項(xiàng)目倉(cāng)庫(kù)
使用以下命令獲取
go get github.com/golang-jwt/jwt
加密
首先聲明一串用于加密解密的秘鑰
mySigningKey := []byte("asfasfdafasdfdasfa.")
然后使用jwt.NewWithClaims
new一個(gè)token,這個(gè)玩意有兩個(gè)參數(shù),返回值就是token
第一個(gè)是加密方法,我這里使用的是hs256加密
第二個(gè)是加密的一些參數(shù),可以使用自帶的jwt.MapClaims
,也可以自定義一個(gè)結(jié)構(gòu)體,如果是自定義結(jié)構(gòu)體需要實(shí)現(xiàn)jwt.StandardClaims
結(jié)構(gòu)體,里面可以定義過(guò)期時(shí)間頒發(fā)者等等
我這里使用的是jwt.MapClaims
,里面也可以定義過(guò)期時(shí)間等等,不同的就是寫法不一樣,我這里舉例子設(shè)置過(guò)期時(shí)間為5秒
token:=jwt.NewWithClaims(jwt.SigningMethodHS256, jwt.MapClaims{ "name": "司大帥", "exp": time.Now().Unix() + 5, "iss": "sywdebug", })
下圖就是token打印出來(lái)的結(jié)果
在將token返回給前端時(shí)候需要使用自己聲明的秘鑰加密一下,再返回給前端
tokenString, err := token.SignedString(mySigningKey) if err != nil { log.Println(err.Error()) return } fmt.Println("加密后的token字符串", tokenString)
在前端登錄時(shí),將加密后的token字符串返回給前端,在調(diào)用需要驗(yàn)證的接口時(shí)將 token 傳回后端,在后端進(jìn)行解密驗(yàn)證
解密
解密使用jwt.Parse
方法,如果上面使用了自定義結(jié)構(gòu)體的話就使用jwt.ParseWithClaims
方法jwt.Parse
有兩個(gè)參數(shù)
第一個(gè)就是加密后的token字符串
第二個(gè)是一個(gè)自帶的回調(diào)函數(shù),將秘鑰和錯(cuò)誤return出來(lái)即可jwt.ParseWithClaims
有三個(gè)參數(shù)
第一個(gè)就是加密后的token字符串
第二個(gè)是加密使用的模板,例如上面示例將qqq傳入即可
第三個(gè)是一個(gè)自帶的回調(diào)函數(shù),將秘鑰和錯(cuò)誤return出來(lái)即可
//在這里如果也使用jwt.ParseWithClaims的話,第二個(gè)參數(shù)就寫jwt.MapClaims{} //例如jwt.ParseWithClaims(tokenString, jwt.MapClaims{},func(t *jwt.Token) (interface{}, error){} token, err = jwt.Parse(tokenString, func(t *jwt.Token) (interface{}, error) { return mySigningKey, nil }) if err != nil { log.Println(err.Error()) return } fmt.Println("token:", token) fmt.Println("token.Claims:", token.Claims) fmt.Println(token.Claims.(jwt.MapClaims)["name"])
上面給的過(guò)期時(shí)間是5秒,如果加一個(gè)6秒的延遲再執(zhí)行解析,就會(huì)返回token已過(guò)期了
到此這篇關(guān)于go語(yǔ)言使用jwt認(rèn)證的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)go語(yǔ)言 jwt認(rèn)證內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Go語(yǔ)言學(xué)習(xí)筆記之文件讀寫操作詳解
這篇文章主要為大家詳細(xì)介紹了Go語(yǔ)言對(duì)文件進(jìn)行讀寫操作的方法,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)Go語(yǔ)言有一定的幫助,需要的可以參考一下2022-05-05Go?通過(guò)?Map/Filter/ForEach?等流式?API?高效處理數(shù)據(jù)的思路詳解
Stream?的實(shí)現(xiàn)思想就是將數(shù)據(jù)處理流程抽象成了一個(gè)數(shù)據(jù)流,每次加工后返回一個(gè)新的流供使用。這篇文章主要介紹了Go?通過(guò)?Map/Filter/ForEach?等流式?API?高效處理數(shù)據(jù),需要的朋友可以參考下2022-01-01淺析go中Ticker,Timer和Tick的用法與區(qū)別
在go面試的時(shí)候,面試官經(jīng)常會(huì)問(wèn)time包的Ticker,Timer以及Tick的區(qū)別,一般在超時(shí)控制的時(shí)候用的比較多,今天就跟隨小編一起來(lái)詳細(xì)學(xué)一下這幾個(gè)的區(qū)別吧2023-10-10Golang打印復(fù)雜結(jié)構(gòu)體兩種方法詳解
在?Golang?語(yǔ)言開發(fā)中,我們經(jīng)常會(huì)使用結(jié)構(gòu)體類型,如果我們使用的結(jié)構(gòu)體類型的變量包含指針類型的字段,我們?cè)谟涗浫罩镜臅r(shí)候,指針類型的字段的值是指針地址,將會(huì)給我們?debug?代碼造成不便2022-10-10goland安裝1.7版本報(bào)錯(cuò)Unpacked?SDK?is?corrupted解決
這篇文章主要為大家介紹了goland安裝1.7版本報(bào)錯(cuò)Unpacked?SDK?is?corrupted解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-11-11