Go语言加解密--AES简单实践

AES加解密的简单实现,代码如下。

package main


import (
    "crypto/aes"
    "crypto/cipher"
    "encoding/hex"
    "fmt"
)

func main(){

    nonce := "37b8e8a308c354048d245f6d"
    key := "AES256Key-32Characters1234567890"
    plainText := "172.10.99.88"
    cipherText :=   ExampleNewGCM_encrypt(plainText, key, nonce)
    newPlain := ExampleNewGCM_decrypt(cipherText, key, nonce)


    fmt.Println("plain:", plainText)
    fmt.Println("cipher:", cipherText)
    fmt.Println("new plain:", newPlain)
}

func ExampleNewGCM_encrypt(src, k, n string)string {
    // The key argument should be the AES key, either 16 or 32 bytes
    // to select AES-128 or AES-256.
    key := []byte(k)
    plaintext := []byte(src)

    block, err := aes.NewCipher(key)
    if err != nil {
        panic(err.Error())
    }

    nonce, _ := hex.DecodeString(n)

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

    ciphertext := aesgcm.Seal(nil, nonce, plaintext, nil)

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

func ExampleNewGCM_decrypt(src, k, n string) string {
    // The key argument should be the AES key, either 16 or 32 bytes
    // to select AES-128 or AES-256.
    key := []byte(k)
    ciphertext, _ := hex.DecodeString(src)

    nonce, _ := hex.DecodeString(n)

    block, err := aes.NewCipher(key)
    if err != nil {
        panic(err.Error())
    }

    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 string(plaintext)
}

Output:

plain: 172.10.99.88
cipher: 4456f9258c204906cbb2516e1fc78c3fbbf439e9e7d49189a391ee33
new plain: 172.10.99.88

参考
https://golang.org/src/crypto/cipher/example_test.go

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值