Go语言的非对称加密(RSA加密)

之前在接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)
  • [顶部附上资源链接,有需要的可以下载看看 ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值