之前在接Android的SDK,流程比较奇葩,然后就需要我在服务器上使用私钥把字符串加密然后在传回Android,而且必须要使用非对称加密(RSA加密),java是有封装好的RSA加密的函数的,但我是用Go写的服务器,然而Go里好像没有原生封装,好像需要加载一个crypto的库,然后来回转换实现,挺麻烦的,后来找朋友问,给我发了一个通过算法封装好的加密和解密的函数,直接使用里面函数就可以了。
- 部分解密代码:
keyBinary := make([]byte, base64.StdEncoding.DecodedLen(len(rsaPublicKey)))
keyLen, err := base64.StdEncoding.Decode(keyBinary, []byte(rsaPublicKey))
if err != nil {
return err
}
keyBinary = keyBinary[:keyLen]
pubInterface, err := x509.ParsePKIXPublicKey(keyBinary)
if err != nil {
return err
}
publicKey := pubInterface.(*rsa.PublicKey)
h := md5.New()
h.Write([]byte(message))
digest := h.Sum(nil)
- [顶部附上资源链接,有需要的可以下载看看 ]