AES加密解密算法里面,最复杂的的就是CFB模式,因为CFB模式每次附加随机一个IV,造成同样的KEY,每次生成的加密串不一样。解密的时候要用到这个IV,IV附加在了加密好的数据里面,有的实现是把IV放数据的最后,有的是最面前,比如加密之后的数据是XXX, 则最终的数据是 16Bytes的IV+XXX或者是XXX+16Bytes的IV。
package main
import (
"crypto/aes"
"crypto/cipher"
"crypto/rand"
"encoding/base64"
"flag"
"fmt"
"io"
"log"
"os"
"errors"
)
var pass = flag.String("pass", "Password111111111111111111111111", "32 char password phrase- can be set to anything but keep it private")
var text = flag.String("text", "HelloWorld", "plain text to encode")
var cipherText = flag.String("cipher", "", "cipher text")
var verbose = flag.Bool("verbose", false, "verbose flag")
func main() {
flag.Parse()
key := []byte(*pass) // 32 bytes
if len(os.Args) < 2 {
println("usage: goAES -pass Password111111111111111111111111 -text HelloWorld")
println("or")
println("usage: goAES -pass Password111111111111111111111111 -cipher HnOnMPZAb32fz1f80VIL2pj

本文介绍了AES加密解密中的CFB模式,由于其每次加密会附加随机IV,导致相同的密钥也会产生不同的加密结果。在Java中,需要特定版本的JCE政策文件以支持256位密钥。同时,对比了GO语言和JAVA中处理256位密钥的不同方式,GO直接使用32字节的字符串,而JAVA将32字节转换为16进制的64字节字符串再转回二进制秘钥。
最低0.47元/天 解锁文章
1079

被折叠的 条评论
为什么被折叠?



