Go 利用crypto实现aes-128-ctr计算方法
高级加密标准(英语:Advanced Encryption Standard,缩写:AES),又称Rijndael加密法,是美国联邦政府采用的一种区块加密标准。这个标准用来替代原先的DES,已经被多方分析且广为全世界所使用。经过五年的甄选流程,高级加密标准由美国国家标准与技术研究院(NIST)于2001年11月26日发布于FIPS PUB 197,并在2002年5月26日成为有效的标准。现在,高级加密标准已然成为对称密钥加密中最流行的算法之一。
aes-192密钥的长度为24字节,aes-256密钥的长度为32字节,aes-128密码的长度为16字节。aes-ctr需要密钥就行和iv,另外aes-ctr不需要填充。
计算器模式(Counter (CTR))
代码:
package main
import (
"bytes"
"crypto/aes"
"crypto/cipher"
"crypto/md5"
"fmt"
)
func main() {
fmt.Println("go crypto aes-128-ctr demo/example.")
message := []byte("https://const.net.cn")
//指定密钥
key := []byte("1234567812345678")
//加密
cipherText := AES_CTR_Encrypt(message, key)
fmt.Printf("加密后:%x\n", cipherText)
fmt.Printf("MD5后为:%x\n", md5.Sum(cipherText))
//解密
plainText := AES_CTR_Decrypt(cipherText, key)
fmt.Println("解密后为:", string(plainText))
}
//AES加密(CTR模式)
func AES_CTR_Encrypt(plainText []byte, key []byte) []byte {
//指定加密算法,返回一个AES算法的Block接口对象
block, err := aes.NewCipher(key)
if err != nil {
panic(err)
}
//指定初始向量vi,长度和block的块尺寸一致
iv := []byte("1234567812345678")
//指定分组模式,返回一个BlockMode接口对象
blockMode := cipher.NewCTR(block, iv)
//加密连续数据库
cipherText := make([]byte, len(plainText))
blockMode.XORKeyStream(cipherText, plainText)
//返回密文
return cipherText
}
//AES解密(CTR模式)
func AES_CTR_Decrypt(cipherText []byte, key []byte) []byte {
//指定解密算法,返回一个AES算法的Block接口对象
block, err := aes.NewCipher(key)
if err != nil {
panic(err)
}
//指定初始化向量IV,和加密的一致
iv := []byte("1234567812345678")
//指定分组模式,返回一个BlockMode接口对象
blockMode := cipher.NewCTR(block, iv)
//解密
plainText := make([]byte, len(cipherText))
blockMode.XORKeyStream(plainText, cipherText)
return plainText
}
输出:
go run .
go crypto aes-128-ctr demo/example.
加密后:05d86826947dd5cf59a0e21be5ca468540c84b98
MD5后为:1facda6cb7539b51eda97b4a9fb7270d
解密后为: https://const.net.cn
php openssl 验证:
<?php
function aes_encrypt($text, $key) {
$cipher_name = "aes-128-ctr";
$iv = pack("H*", "31323334353637383132333435363738");
$key = pack("H*", $key);
$encrypted = openssl_encrypt($text, $cipher_name, $key, OPENSSL_RAW_DATA, $iv);
echo "cipher_name = ".$cipher_name."\n";
echo "plaintext = ".$text."\n";
echo "md5 = ".md5($encrypted)."\n";
return bin2hex($encrypted);
}
echo "aes-128-ctr cipher_text = ".aes_encrypt('https://const.net.cn', '31323334353637383132333435363738')."\n";
?>
输出:
php7.4 php/openssl.php
cipher_name = aes-128-ctr
plaintext = https://const.net.cn
md5 = 1facda6cb7539b51eda97b4a9fb7270d
aes-128-ctr cipher_text = 05d86826947dd5cf59a0e21be5ca468540c84b98