国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

目錄
問(wèn)題內(nèi)容
解決方法
首頁(yè) 後端開(kāi)發(fā) Golang Go 中的 Azure JWT 驗(yàn)證不起作用

Go 中的 Azure JWT 驗(yàn)證不起作用

Feb 09, 2024 am 11:12 AM
go語(yǔ)言 安全傳輸

Go 中的 Azure JWT 驗(yàn)證不起作用

在使用Go語(yǔ)言開(kāi)發(fā)Azure應(yīng)用程式時(shí),經(jīng)常會(huì)遇到JWT(JSON Web Token)驗(yàn)證不起作用的問(wèn)題。 JWT是一種用於在網(wǎng)路應(yīng)用程式間傳遞聲明的安全傳輸方式,但有時(shí)在Go中使用Azure的JWT驗(yàn)證時(shí)會(huì)遇到各種問(wèn)題。本文將為您介紹一些可能導(dǎo)致JWT驗(yàn)證不起作用的原因,並提供相應(yīng)的解決方案,幫助您解決這個(gè)常見(jiàn)的問(wèn)題。本文經(jīng)過(guò)php小編蘋果精心整理,希望對(duì)您有幫助。

問(wèn)題內(nèi)容

我有一個(gè) go http 伺服器。我想使用 azure jwt 令牌保護(hù)我的路由。我能夠生成令牌,但無(wú)法驗(yàn)證它。

我就是這樣做的:

package main

import (
    "context"
    "errors"
    "fmt"

    "github.com/dgrijalva/jwt-go"
    "github.com/lestrrat-go/jwx/jwa"
    "github.com/lestrrat-go/jwx/jwk"
    njwt "github.com/lestrrat-go/jwx/jwt"
)

const token = "<access-token>"

const jwksurl = `https://login.microsoftonline.com/common/discovery/keys`

func main() {
    set, _ := jwk.fetch(context.todo(), jwksurl)
    // verified that set has required kid 
    verify2(token, set)
    token, err := verify(token, set)
    // token, err := jwt.parse(token, getkey)
    if err != nil {
        panic(err)
    }
    claims := token.claims.(jwt.mapclaims)
    for key, value := range claims {
        fmt.printf("%s\t%v\n", key, value)
    }
}

func verify2(token string, keyset jwk.set) {
    btoken := []byte(token)
    parsedtoken, err := njwt.parse(
        btoken, //token is a []byte
        njwt.withkeyset(keyset),
        njwt.withvalidate(true),
    )
    fmt.printf("%v %v", parsedtoken, err)
}

func verify(tokenstring string, keyset jwk.set) (*jwt.token, error) {
    tkn, err := jwt.parse(tokenstring, func(token *jwt.token) (interface{}, error) {
        if token.method.alg() != jwa.rs256.string() {
            return nil, fmt.errorf("unexpected signing method: %v", token.header["alg"])
        }
        kid, ok := token.header["kid"].(string)
        if !ok {
            return nil, errors.new("kid header not found")
        }
        keys, ok := keyset.lookupkeyid(kid)
        if !ok {
            return nil, fmt.errorf("key %v not found", kid)
        }
        var raw interface{}
        err := keys.raw(&raw)
        return raw, err
    })
    return tkn, err
}

verify2(..)<nil> 未能匹配任何鍵 verify(..) 給出 crypto/rsa: 驗(yàn)證錯(cuò)誤

#我的 jwt 標(biāo)頭:

{
  "typ": "JWT",
  "nonce": "...",
  "alg": "RS256",
  "x5t": "-KI3Q9nNR7bRofxmeZoXqbHZGew",
  "kid": "-KI3Q9nNR7bRofxmeZoXqbHZGew"
}

解決方法

您使用的 Azure AD 存取權(quán)杖類型錯(cuò)誤。 JWT 標(biāo)頭中帶有隨機(jī)數(shù)的內(nèi)容並非旨在由您自己的 API 進(jìn)行驗(yàn)證 - 它們適用於 Microsoft 自己的 API。

您需要公開(kāi)一個(gè) API 範(fàn)圍來(lái)解決此問(wèn)題,之後您將獲得一個(gè)存取令牌,而 JWT 標(biāo)頭中沒(méi)有隨機(jī)數(shù)。我的部落格文章有一些進(jìn)一步的相關(guān)資訊。

以上是Go 中的 Azure JWT 驗(yàn)證不起作用的詳細(xì)內(nèi)容。更多資訊請(qǐng)關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本網(wǎng)站聲明
本文內(nèi)容由網(wǎng)友自願(yuàn)投稿,版權(quán)歸原作者所有。本站不承擔(dān)相應(yīng)的法律責(zé)任。如發(fā)現(xiàn)涉嫌抄襲或侵權(quán)的內(nèi)容,請(qǐng)聯(lián)絡(luò)admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅(qū)動(dòng)的應(yīng)用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費(fèi)的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強(qiáng)大的PHP整合開(kāi)發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺(jué)化網(wǎng)頁(yè)開(kāi)發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級(jí)程式碼編輯軟體(SublimeText3)

在Go語(yǔ)言中使用Redis Stream實(shí)現(xiàn)消息隊(duì)列時(shí),如何解決user_id類型轉(zhuǎn)換問(wèn)題? 在Go語(yǔ)言中使用Redis Stream實(shí)現(xiàn)消息隊(duì)列時(shí),如何解決user_id類型轉(zhuǎn)換問(wèn)題? Apr 02, 2025 pm 04:54 PM

Go語(yǔ)言中使用RedisStream實(shí)現(xiàn)消息隊(duì)列時(shí)類型轉(zhuǎn)換問(wèn)題在使用Go語(yǔ)言與Redis...

GoLand中自定義結(jié)構(gòu)體標(biāo)籤不顯示怎麼辦? GoLand中自定義結(jié)構(gòu)體標(biāo)籤不顯示怎麼辦? Apr 02, 2025 pm 05:09 PM

GoLand中自定義結(jié)構(gòu)體標(biāo)籤不顯示怎麼辦?在使用GoLand進(jìn)行Go語(yǔ)言開(kāi)發(fā)時(shí),很多開(kāi)發(fā)者會(huì)遇到自定義結(jié)構(gòu)體標(biāo)籤在?...

Go的爬蟲Colly中Queue線程的問(wèn)題是什麼? Go的爬蟲Colly中Queue線程的問(wèn)題是什麼? Apr 02, 2025 pm 02:09 PM

Go爬蟲Colly中的Queue線程問(wèn)題探討在使用Go語(yǔ)言的Colly爬蟲庫(kù)時(shí),開(kāi)發(fā)者常常會(huì)遇到關(guān)於線程和請(qǐng)求隊(duì)列的問(wèn)題。 ?...

在 Go 語(yǔ)言中,為什麼使用 Println 和 string() 函數(shù)打印字符串會(huì)出現(xiàn)不同的效果? 在 Go 語(yǔ)言中,為什麼使用 Println 和 string() 函數(shù)打印字符串會(huì)出現(xiàn)不同的效果? Apr 02, 2025 pm 02:03 PM

Go語(yǔ)言中字符串打印的區(qū)別:使用Println與string()函數(shù)的效果差異在Go...

Go語(yǔ)言中哪些庫(kù)是由大公司開(kāi)發(fā)或知名的開(kāi)源項(xiàng)目提供的? Go語(yǔ)言中哪些庫(kù)是由大公司開(kāi)發(fā)或知名的開(kāi)源項(xiàng)目提供的? Apr 02, 2025 pm 04:12 PM

Go語(yǔ)言中哪些庫(kù)是大公司開(kāi)發(fā)或知名開(kāi)源項(xiàng)目?在使用Go語(yǔ)言進(jìn)行編程時(shí),開(kāi)發(fā)者常常會(huì)遇到一些常見(jiàn)的需求,?...

Go語(yǔ)言中用於浮點(diǎn)數(shù)運(yùn)算的庫(kù)有哪些? Go語(yǔ)言中用於浮點(diǎn)數(shù)運(yùn)算的庫(kù)有哪些? Apr 02, 2025 pm 02:06 PM

Go語(yǔ)言中用於浮點(diǎn)數(shù)運(yùn)算的庫(kù)介紹在Go語(yǔ)言(也稱為Golang)中,進(jìn)行浮點(diǎn)數(shù)的加減乘除運(yùn)算時(shí),如何確保精度是?...

使用Go語(yǔ)言連接Oracle數(shù)據(jù)庫(kù)時(shí)是否需要安裝Oracle客戶端? 使用Go語(yǔ)言連接Oracle數(shù)據(jù)庫(kù)時(shí)是否需要安裝Oracle客戶端? Apr 02, 2025 pm 03:48 PM

使用Go語(yǔ)言連接Oracle數(shù)據(jù)庫(kù)時(shí)是否需要安裝Oracle客戶端?在使用Go語(yǔ)言開(kāi)發(fā)時(shí),連接Oracle數(shù)據(jù)庫(kù)是一個(gè)常見(jiàn)需求?...

在Go編程中,如何正確管理Mysql和Redis的連接與釋放資源? 在Go編程中,如何正確管理Mysql和Redis的連接與釋放資源? Apr 02, 2025 pm 05:03 PM

Go編程中的資源管理:Mysql和Redis的連接與釋放在學(xué)習(xí)Go編程過(guò)程中,如何正確管理資源,特別是與數(shù)據(jù)庫(kù)和緩存?...

See all articles