亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

在 Go 中驗證有效負載的簽名

在 Go 中驗證有效負載的簽名

Go
aluckdog 2021-11-01 15:07:50
我正在驗證一條數據的發送者的身份。我收到了 PEM 格式的 RSA 公鑰,我知道數據是通過 SHA256 散列函數傳遞的。node.js平臺上的等效驗證:Ticket.prototype.verify = function (ticket) {    if (!ticket) return null;    var pubkey = fs.readFileSync('/etc/SCAMP/auth/ticket_verify_public_key.pem');    var parts = ticket.split(',');    if (parts[0] != '1') return null;    var sig = new Buffer(parts.pop().replace(/-/g,'+').replace(/_/g,'/'), 'base64');    var valid = crypto.createVerify('sha256').update( new Buffer(parts.join(',')) ).verify( pubkey, sig )哪個可以驗證:1,3063,21,1438783424,660,1+20+31+32+34+35+36+37+38+39+40+41+42+43+44+46+47+48+50+53+56+59+60+61+62+67+68+69+70+71+75+76+80+81+82+86+87+88+102+104+105+107+109+110+122+124,PcFNyWjoz_iiVMgEe8I3IBfzSlUcqUGtsuN7536PTiBW7KDovIqCaSi_8nZWcj-j1dfbQRA8mftwYUWMhhZ4DD78-BH8MovNVucbmTmf2Wzbx9bsI-dmUADY5Q2ol4qDXG4YQJeyZ6f6F9s_1uxHTH456QcsfNxFWh18ygo5_DVmQQSXCHN7EXM5M-u2DSol9MSROeBolYnHZyE093LgQ2veWQREbrwg5Fcp2VZ6VqIC7yu6f_xYHEvU0-ZsSSRMAMUmhLNhmFM4KDjl8blVgC134z7XfCTDDjCDiynSL6b-D-通過在最后一個分裂,。分割線左邊是我關心的工單數據,右邊是我需要驗證的簽名,才能使用工單數據。我試圖移植邏輯去:func TestSigVerification(t *testing.T) {    block, _ := pem.Decode(signingPubKey)    if block == nil {        t.Errorf("expected to block to be non-nil CERTIFICATE", block)    }    key, err := x509.ParsePKIXPublicKey(block.Bytes)    if err != nil {        t.Errorf("could not parse PKIXPublicKey: `%s`", key)    }    rsaPubKey, ok := key.(*rsa.PublicKey)    if !ok {        t.Errorf("couldn't cast to rsa.PublicKey!")    }    ticket,_ := ParseTicketBytes(fullTicketBytes)    h := sha256.New()    h.Write(ticketBytes)    digest := h.Sum(nil)    err = rsa.VerifyPKCS1v15(rsaPubKey, crypto.SHA256, digest, ticket.Signature)    if err != nil {        t.Errorf("could not verify ticket: `%s` (digest: `%v`)", err, digest )    }}但是我很確定VerifyPKCS1v15它不等同于 nodecrypto.createVerify并且這個測試用例失敗了。我應該使用什么?如何使用公鑰解密簽名并獲得sha256?一旦我有了解密的 sha256 值,我就可以與我生成的 sha256 進行基本比較。這是一個可運行的游樂場示例:http : //play.golang.org/p/COx2OG-AiA
查看完整描述

2 回答

?
慕運維8079593

TA貢獻1876條經驗 獲得超5個贊

我嘗試運行您的代碼,但看起來您的票證格式不正確。時間不夠長。你從哪里得到的價值?

仔細檢查那張票——這可能足以讓你去。


查看完整回答
反對 回復 2021-11-01
  • 2 回答
  • 0 關注
  • 141 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號