第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問(wèn)題,去搜搜看,總會(huì)有你想問(wèn)的

如何驗(yàn)證 appengine.SignBytes 返回的簽名?

如何驗(yàn)證 appengine.SignBytes 返回的簽名?

Go
慕哥6287543 2021-11-08 14:34:20
Google App Engine 的 Go 運(yùn)行時(shí)具有SignBytes函數(shù)、PublicCertificates函數(shù)和證書(shū)結(jié)構(gòu)。功能符號(hào)字節(jié)func SignBytes(c Context, bytes []byte) (keyName string, signature []byte, err error) SignBytes 使用您的應(yīng)用程序唯一的私鑰對(duì)字節(jié)進(jìn)行簽名。func 公共證書(shū)func PublicCertificates(c Context) ([]Certificate, error) PublicCertificates 檢索應(yīng)用程序的公共證書(shū)。它們可用于驗(yàn)證 SignBytes 返回的簽名。類(lèi)型證書(shū)type Certificate struct {    KeyName string    Data    []byte // PEM-encoded X.509 certificate}Certificate 代表應(yīng)用程序的公共證書(shū)。很明顯,應(yīng)用程序需要遍歷公共證書(shū)以驗(yàn)證簽名。但尚不清楚簽名是如何生成或驗(yàn)證的。Go 的rsa 包有兩個(gè)函數(shù)來(lái)驗(yàn)證簽名,VerifyPKCS1v15和VerifyPSS,每個(gè)函數(shù)都以一個(gè)crypto.Hash標(biāo)識(shí)符作為參數(shù)。目前,有 15 種不同的哈希標(biāo)識(shí)符(例如,crypto.MD5、crypto.SHA256)給出驗(yàn)證函數(shù)和哈希標(biāo)識(shí)符的 2x15=30 組合。SignBytes 生成的簽名是如何驗(yàn)證的?
查看完整描述

1 回答

?
catspeake

TA貢獻(xiàn)1111條經(jīng)驗(yàn) 獲得超0個(gè)贊

使用 SHA256 驗(yàn)證 PKCS1v15

我通過(guò)嘗試驗(yàn)證方案和哈希類(lèi)型的所有組合發(fā)現(xiàn)了這一點(diǎn);我沒(méi)有找到保證這是將使用的簽名方案的文檔。


但是對(duì)于無(wú)畏者來(lái)說(shuō),下面是一個(gè)對(duì)數(shù)據(jù)進(jìn)行簽名并驗(yàn)證簽名的代碼示例。


package yourpackage


import (

    "crypto"

    "crypto/rsa"

    "crypto/x509"

    "encoding/pem"

    "errors"

    "google.golang.org/appengine"

    "net/http"

)


func signAndVerify(request *http.Request) error {

    c := appengine.NewContext(request)

    data := []byte("test data to sign")

    _, sig, err := appengine.SignBytes(c, data)

    if err != nil {

        return err

    }


    certs, err := appengine.PublicCertificates(c)

    if err != nil {

        return err

    }


    lastErr := errors.New("ErrNoPublicCertificates")


    for _, cert := range certs {

        block, _ := pem.Decode(cert.Data)

        if block == nil {

            lastErr = errors.New("ErrPemDecodeFailure")

            continue

        }

        x509Cert, err := x509.ParseCertificate(block.Bytes)

        if err != nil {

            lastErr = err

            continue

        }

        pubkey, ok := x509Cert.PublicKey.(*rsa.PublicKey)

        if !ok {

            lastErr = errors.New("ErrNotRSAPublicKey")

            continue

        }


        signBytesHash := crypto.SHA256

        h := signBytesHash.New()

        h.Write(data)

        hashed := h.Sum(nil)

        err = rsa.VerifyPKCS1v15(pubkey, signBytesHash, hashed, sig)

        if err != nil {

            lastErr = err

            continue

        }


        return nil

    }


    return lastErr

}

我還在github 上的一個(gè)包中發(fā)布了驗(yàn)證步驟。


更新

Google 提供了一些驗(yàn)證 SignBytes 的示例代碼。其中,有一個(gè)文件app-identity-samples-read-only/python/app_identity_test.py有一個(gè)名為buildjwt創(chuàng)建由 SignBytes 簽名的 JWT 的方法,并且 JWT 算法是 RS256,它在RFC 7518 中定義為使用 SHA-256 的 RSASSA-PKCS1-v1_5。


注意:我將Go App Engine 用于托管 VM(請(qǐng)參閱“google.golang.org/appengine”導(dǎo)入)而不是經(jīng)典的 Go App Engine 運(yùn)行時(shí),盡管對(duì)于 SignBytes 的目的來(lái)說(shuō)并沒(méi)有太大的不同。


查看完整回答
反對(duì) 回復(fù) 2021-11-08
  • 1 回答
  • 0 關(guān)注
  • 225 瀏覽
慕課專(zhuān)欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢(xún)優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)