json - 从 Golang 中的模数和指数创建公钥

标签 json go oauth-2.0 rsa google-oauth

我从第一个证书中获取:https://www.googleapis.com/oauth2/v2/certs 'n' 和 'e' 键值。 Go中是否有一个包可以用'n'和'e'构建公钥?我不知道使用 crypto/rsa 包是如何完成的。一些代码将是宝贵的。谢谢。

最佳答案

rsa 包有一个 PublicKey键入字段 NE。按照 JWA draft 中的描述解码部分应该非常简单。 .

这是一些快速破解的代码(Playground):

package main

import (
    "bytes"
    "crypto/rsa"
    "encoding/base64"
    "encoding/binary"
    "fmt"
    "math/big"
)

func main() {
    nStr := "AN+7p8kw1A3LXfAJi+Ui4o8F8G0EeB4B5RuufglWa4AkadDaLTxGLNtY/NtyRZBfwhdAmRjKQJTVgn5j3y0s+j/bvpzMktoVeHB7irOhxDnZJdIxNNMY3nUKBgQB81jg8lNTeBrJqELSJiRXQIe5PyWJWwQJ1XrtfQNcwGkICM1L"
    decN, err := base64.StdEncoding.DecodeString(nStr)
    if err != nil {
        fmt.Println(err)
        return
    }
    n := big.NewInt(0)
    n.SetBytes(decN)

    eStr := "AQAB"
    decE, err := base64.StdEncoding.DecodeString(eStr)
    if err != nil {
        fmt.Println(err)
        return
    }
    var eBytes []byte
    if len(decE) < 8 {
        eBytes = make([]byte, 8-len(decE), 8)
        eBytes = append(eBytes, decE...)
    } else {
        eBytes = decE
    }
    eReader := bytes.NewReader(eBytes)
    var e uint64
    err = binary.Read(eReader, binary.BigEndian, &e)
    if err != nil {
        fmt.Println(err)
        return
    }
    pKey := rsa.PublicKey{N: n, E: int(e)}
}

关于json - 从 Golang 中的模数和指数创建公钥,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25179492/

相关文章:

php - 如何在 IOS 上使用 Swift 解析从 PHP 服务脚本发送的 JSON?

javascript - 为初学者在 javascript 中构建类

java - 有没有办法从客户端的 google oauth2.0 token 获取 firebase 身份验证 token

ios - 将 Facebook iOS SSO 用于打包的 Web 应用程序?

json - 当json在 native react 中获取时未定义

java - 如何在 Gson 中制作自定义列表反序列化器?

windows - TerminateProcess() 返回 EINVAL

go - 比较不同类型的两个值(但基础类型相同)

json - 序列化为 JSON 时,如何根据运行时条件省略某些字段?

c# - 注册IdentityServer3后自动登录本地用户