Go语言中如何使用AES加密和解密数据?

go语言中如何使用aes加密和解密数据?

go 中的 aes 加密方法

在 go 编程语言中,可以借助 crypto/aes 和 encoding/base64 库轻松地对数据进行 aes 加密。

以下代码展示了一种实现 aes/ecb/nopadding 加密的方法:

package mainimport (    "crypto/aes"    "encoding/base64"    "log")func main() {    str := []byte("406bf0ad11310101220213481000320000")    key := []byte("er2fb6ts3ecx")    encrypted, err := aesencryptecb(str, key)    if err != nil {        log.fatal(err)    }    decrypted, err := aesdecryptecb(encrypted, key)    if err != nil {        log.fatal(err)    }    log.println("encrypted:", encrypted)    log.println("decrypted:", string(decrypted))}func aesencryptecb(origdata []byte, key []byte) (string, error) {    cipher, err := aes.newcipher(generatekey(key))    if err != nil {        return "", err    }    length := (len(origdata) + aes.blocksize) / aes.blocksize    plain := make([]byte, length*aes.blocksize)    copy(plain, origdata)    encrypted := make([]byte, len(plain))    // block encryption    for bs, be := 0, cipher.blocksize(); bs <= len(origdata); bs, be = bs+cipher.blocksize(), be+cipher.blocksize() {        cipher.encrypt(encrypted[bs:be], plain[bs:be])    }    return base64.stdencoding.encodetostring(encrypted), nil}func aesdecryptecb(str string, key []byte) ([]byte, error) {    encrypted, err := base64.stdencoding.decodestring(str)    if err != nil {        return nil, err    }    cipher, err := aes.newcipher(generatekey(key))    if err != nil {        return nil, err    }    decrypted := make([]byte, len(encrypted))    for bs, be := 0, cipher.blocksize(); bs  0 {        trim = len(decrypted) - int(decrypted[len(decrypted)-1])    }    return decrypted[:trim], nil}func generatekey(key []byte) (genkey []byte) {    genkey = make([]byte, 16)    copy(genkey, key)    for i := 16; i < len(key); {        for j := 0; j < 16 && i < len(key); j, i = j+1, i+1 {            genkey[j] ^= key[i]        }    }    return genkey}

登录后复制

以下是使用此方法加密和解密数据的示例:

立即学习“go语言免费学习笔记(深入)”;

str := []byte("406bf0ad11310101220213481000320000")key := []byte("er2fb6ts3ecx")encrypted, err := aesencryptecb(str, key)if err != nil {    log.fatal(err)}decrypted, err := aesdecryptecb(encrypted, key)if err != nil {    log.fatal(err)}log.println("encrypted:", encrypted)log.println("decrypted:", string(decrypted))

登录后复制

输出:

Encrypted: rebZn7aj61hD3lfsUrhwFgVzPg4yYo9aseP/a4sNTRIh/Vtb0mziFfoHdOZBZ5ujDecrypted: 406BF0AD11310101220213481000320000

登录后复制

以上就是Go语言中如何使用AES加密和解密数据?的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2315942.html

(0)
上一篇 2025年2月28日 14:40:44
下一篇 2025年2月20日 06:23:20

AD推荐 黄金广告位招租... 更多推荐

相关推荐

发表回复

登录后才能评论