4 votes

Comment convertir une interface{} en type *rsa.PublicKey golang

J'ai une clé publique stockée dans une variable de type interface{}.

-----BEGIN PUBLIC KEY-----    MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDdlatRjRjogo3WojgGHFHYLugdUWAY9iR3fy4arWNA1KoS8kVw33cJibXr8bvwUAUparCwlvdbH6dvEOfou0/gCFQsHUfQrSDv+MuSUMAe8jzKE4qW+jK+xQU9a03GUnKHkkle+Q0pX/g6jXZ7r1/xAK5Do2kQ+X5xK9cipRgEKwIDAQAB
-----END PUBLIC KEY-----

Existe-t-il un moyen de convertir cela en type *rsa.PublicKey en golang. Cela pourrait nécessiter une étape intermédiaire comme convertir d'abord interface{} en string.

2voto

Kyle Brandt Points 3343

En général, vous décoderiez un fichier pem (en supposant qu'il s'agisse d'un certificat x509) en utilisant la bibliothèque crypto/x509. L'exemple fourni dans la documentation se présente comme suit :

package main

import (
    "crypto/dsa"
    "crypto/ecdsa"
    "crypto/rsa"
    "crypto/x509"
    "encoding/pem"
    "fmt"
)

func main() {
    const pubPEM = `
-----BEGIN PUBLIC KEY-----
MIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAlRuRnThUjU8/prwYxbty
WPT9pURI3lbsKMiB6Fn/VHOKE13p4D8xgOCADpdRagdT6n4etr9atzDKUSvpMtR3
CP5noNc97WiNCggBjVWhs7szEe8ugyqF23XwpHQ6uV1LKH50m92MbOWfCtjU9p/x
qhNpQQ1AZhqNy5Gevap5k8XzRmjSldNAFZMY7Yv3Gi+nyCwGwpVtBUwhuLzgNFK/
yDtw2WcWmUU7NuC8Q6MWvPebxVtCfVp/iQU6q60yyt6aGOBkhAX0LpKAEhKidixY
nP9PNVBvxgu3XZ4P36gZV6+ummKdBVnc3NqwBLu5+CcdRdusmHPHd5pHf4/38Z3/
6qU2a/fPvWzceVTEgZ47QjFMTCTmCwNt29cvi7zZeQzjtwQgn4ipN9NibRH/Ax/q
TbIzHfrJ1xa2RteWSdFjwtxi9C20HUkjXSeI4YlzQMH0fPX6KCE7aVePTOnB69I/
a9/q96DiXZajwlpq3wFctrs1oXqBp5DVrCIj8hU2wNgB7LtQ1mCtsYz//heai0K9
PhE4X6hiE0YmeAZjR0uHl8M/5aW9xCoJ72+12kKpWAa0SFRWLy6FejNYCYpkupVJ
yecLk/4L1W0l6jQQZnWErXZYe0PNFcmwGXy1Rep83kfBRNKRy5tvocalLlwXLdUk
AIU+2GKjyT3iMuzZxxFxPFMCAwEAAQ==
-----END PUBLIC KEY-----`

    block, _ := pem.Decode([]byte(pubPEM))
    if block == nil {
        panic("échec lors de l'analyse du bloc PEM contenant la clé publique")
    }

    pub, err := x509.ParsePKIXPublicKey(block.Bytes)
    if err != nil {
        panic("échec lors de l'analyse de la clé publique encodée en DER : " + err.Error())
    }

    switch pub := pub.(type) {
    case *rsa.PublicKey:
        fmt.Println("pub est de type RSA :", pub)
    case *dsa.PublicKey:
        fmt.Println("pub est de type DSA :", pub)
    case *ecdsa.PublicKey:
        fmt.Println("pub est de type ECDSA :", pub)
    default:
        panic("type de clé publique inconnu")
    }
}

Cependant, je ne suis pas vraiment sûr de l'encodage que vous avez là. Les informations suivantes pourraient vous aider à surmonter cette difficulté :

1voto

uwevil Points 124

Vous pouvez utiliser: rsaPublickey, _ := pub.(*rsa.PublicKey) pour convertir en rsa.PublicKey

Prograide.com

Prograide est une communauté de développeurs qui cherche à élargir la connaissance de la programmation au-delà de l'anglais.
Pour cela nous avons les plus grands doutes résolus en français et vous pouvez aussi poser vos propres questions ou résoudre celles des autres.

Powered by:

X