GoLang AES GSM

aside section ._1OhGeD · · 650 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

以太坊Whisper协议中,默认的对称加密使用的是AES-GCM加密算法。

AES是一种对称加密算法,它的相关概念在此不赘述。

GCM ( Galois/Counter Mode) 指的是该对称加密采用Counter模式,并带有GMAC消息认证码。

在详细介绍AES-GCM之前,我们先了解一些相关概念。
https://blog.csdn.net/T0mato_/article/details/53160772

1、准备

// AesKey 密钥
var AesKey string = "HQECux7Tt6UrGOUl"

// nonce 初始向量
nonce, _ := hex.DecodeString("000000010000010000000010")

2、辅助函数

func getKeys() ([]byte) {
    return []byte(AesKey)
}

func getBlock() cipher.Block {
    key := getKeys()
    block, err := aes.NewCipher(key)
    if err != nil {
        panic(err.Error())
    }
    return block
}

func getNonce() []byte {
    nonce, err := hex.DecodeString(Gsm_IV)
    if err != nil {
        panic(err.Error())
    }
    return nonce
}

3、encrypt

func encrypt(data string) (string) {
    block := getBlock()
    nonce := getNonce()
    aesgcm, err := cipher.NewGCM(block)
    if err != nil {
        panic(err.Error())
    }
    cipherText := aesgcm.Seal(nil, nonce, []byte(data), nil)
    return fmt.Sprintf("%x", cipherText)
}

4、decrypt

func decrypt(data string) string {
    cipherText, _ := hex.DecodeString(data)

    nonce := getNonce()
    block := getBlock()

    aesgcm, err := cipher.NewGCM(block)
    if err != nil {
        panic(err.Error())
    }
    plaintext, err := aesgcm.Open(nil, nonce, cipherText, nil)
    if err != nil {
        panic(err.Error())
    }

    return fmt.Sprintf("%x", plaintext)
}

有疑问加站长微信联系(非本文作者)

本文来自:简书

感谢作者:aside section ._1OhGeD

查看原文:GoLang AES GSM

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

650 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传