在Linux环境下使用Go语言(Golang)实现数据的加密与解密,可以利用Go标准库中的crypto包。以下是使用对称加密算法AES(高级加密标准)进行数据加密和解密的示例代码。
package main
import (
"crypto/aes"
"crypto/cipher"
"crypto/rand"
"encoding/base64"
"fmt"
"io"
)
// 加密函数
func encrypt(plainText string, key []byte) (cipherText string, err error) {
// 创建一个AES块
block, err := aes.NewCipher(key)
if err != nil {
return "", err
}
// 生成随机IV
iv := make([]byte, aes.BlockSize)
if _, err := io.ReadFull(rand.Reader, iv); err != nil {
return "", err
}
// 创建一个cipher.BlockMode实例
mode := cipher.NewCBCEncrypter(block, iv)
// 填充明文
plainTextBytes := []byte(plainText)
padding := aes.BlockSize - len(plainTextBytes)%aes.BlockSize
padText := bytes.Repeat([]byte{byte(padding)}, padding)
plainTextBytes = append(plainTextBytes, padText...)
// 加密数据
cipherTextBytes := make([]byte, len(plainTextBytes))
mode.CryptBlocks(cipherTextBytes, plainTextBytes)
// 返回Base64编码的密文和IV
cipherText = base64.StdEncoding.EncodeToString(cipherTextBytes)
return cipherText, nil
}
// 解密函数
func decrypt(cipherText string, key []byte) (plainText string, err error) {
// 解码Base64密文
cipherTextBytes, err := base64.StdEncoding.DecodeString(cipherText)
if err != nil {
return "", err
}
// 创建一个AES块
block, err := aes.NewCipher(key)
if err != nil {
return "", err
}
// 创建一个cipher.BlockMode实例
iv := cipherTextBytes[:aes.BlockSize]
mode := cipher.NewCBCDecrypter(block, iv)
// 解密数据
plainTextBytes := make([]byte, len(cipherTextBytes)-aes.BlockSize)
mode.CryptBlocks(plainTextBytes, cipherTextBytes[aes.BlockSize:])
// 去除填充
padding := plainTextBytes[len(plainTextBytes)-1]
plainTextBytes = plainTextBytes[:len(plainTextBytes)-int(padding)]
// 返回明文
plainText = string(plainTextBytes)
return plainText, nil
}
func main() {
key := []byte("1234567890123456") // 16字节密钥
plainText := "Hello, World!"
// 加密
cipherText, err := encrypt(plainText, key)
if err != nil {
fmt.Println("加密失败:", err)
return
}
fmt.Println("加密后的密文:", cipherText)
// 解密
decryptedText, err := decrypt(cipherText, key)
if err != nil {
fmt.Println("解密失败:", err)
return
}
fmt.Println("解密后的明文:", decryptedText)
}
加密函数 encrypt:
解密函数 decrypt:
通过这种方式,你可以在Linux环境下使用Go语言实现数据的加密和解密。