golang 对接第三方接口 RSA 做签(加密) 验签(解密)
在Go语言中,你可以使用crypto/rsa
包来进行RSA加密和解密。以下是一个简单的例子,展示了如何使用公钥进行签名(加密)和如何使用私钥进行验签(解密)。
package main
import (
"crypto/rand"
"crypto/rsa"
"crypto/x509"
"encoding/pem"
"fmt"
)
func main() {
// 生成RSA密钥对
privateKey, err := rsa.GenerateKey(rand.Reader, 2048)
if err != nil {
panic(err)
}
publicKey := &privateKey.PublicKey
// 签名
message := []byte("Hello, third-party API!")
signature, err := rsa.SignPKCS1v15(rand.Reader, privateKey, crypto.SHA256, message)
if err != nil {
panic(err)
}
fmt.Printf("Signature: %x\n", signature)
// 验签
err = rsa.VerifyPKCS1v15(publicKey, crypto.SHA256, message, signature)
if err != nil {
panic(err)
}
fmt.Println("Verification succeeded!")
}
在这个例子中,我们首先生成了一个RSA密钥对。然后,我们使用私钥对一个消息进行了签名,生成了加密的签名。最后,我们使用公钥验证了这个签名,确保消息的完整性。
请注意,这个例子是为了演示目的而简化的。在实际应用中,密钥的生成和管理应该更加安全,密钥可能会从外部源(例如密钥管理服务)加载,签名和验签的过程可能会更加复杂,涉及到与第三方接口的协议约定。
评论已关闭