分享
Golang1.7.3使用标准库的AES加密解密不实用扩展协议
fyxichen · · 1578 次点击 · · 开始浏览这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。
package main
import (
"crypto/aes"
"crypto/cipher"
"fmt"
)
type tobytes struct {
cip cipher.Block
pdgtext []byte
}
func main() {
cip, _ := aes.NewCipher([]byte("1234567891234567"))
enc := &tobytes{cip: cip, pdgtext: make([]byte, cip.BlockSize())}
src := enc.Encrypt([]byte("czxichen"))
dst := enc.Decrypt(src)
fmt.Println(string(dst))
}
//使用AES加密文本,加密的文本不能为空
func (a *tobytes) Encrypt(src []byte) (dst []byte) {
src = a.padding(src)
dst = make([]byte, len(src))
var index int = 0
for len(src) > 0 {
a.cip.Encrypt(dst[index:index+a.cip.BlockSize()], src)
index += a.cip.BlockSize()
src = src[a.cip.BlockSize():]
}
return dst
}
//使用AES解密文本
func (a *tobytes) Decrypt(src []byte) (dst []byte) {
if len(src)%a.cip.BlockSize() != 0 {
return src
}
dst = make([]byte, len(src))
var index int = 0
for len(src) > 0 {
a.cip.Decrypt(dst[index:index+a.cip.BlockSize()], src)
index += a.cip.BlockSize()
src = src[a.cip.BlockSize():]
}
return a.unpadding(dst)
}
//使用AES加密文本的时候文本必须定长,即必须是16,24,32的整数倍,
func (a *tobytes) padding(src []byte) (dst []byte) {
pdg := a.cip.BlockSize() - len(src)%a.cip.BlockSize()
p := a.pdgtext[:pdg]
p[pdg-1] = byte(pdg)
return append(src, p...)
}
//使用AES解密文本,解密收删除padding的文本
func (a *tobytes) unpadding(src []byte) (dst []byte) {
length := len(src)
if length <= 0 {
return src
}
return src[:(length - int(src[length-1]))]
}
有疑问加站长微信联系(非本文作者)
入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889
关注微信1578 次点击
下一篇:Golang 限速器
添加一条新回复
(您需要 后才能回复 没有账号 ?)
- 请尽量让自己的回复能够对别人有帮助
- 支持 Markdown 格式, **粗体**、~~删除线~~、
`单行代码` - 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
- 图片支持拖拽、截图粘贴等方式上传
收入到我管理的专栏 新建专栏
package main
import (
"crypto/aes"
"crypto/cipher"
"fmt"
)
type tobytes struct {
cip cipher.Block
pdgtext []byte
}
func main() {
cip, _ := aes.NewCipher([]byte("1234567891234567"))
enc := &tobytes{cip: cip, pdgtext: make([]byte, cip.BlockSize())}
src := enc.Encrypt([]byte("czxichen"))
dst := enc.Decrypt(src)
fmt.Println(string(dst))
}
//使用AES加密文本,加密的文本不能为空
func (a *tobytes) Encrypt(src []byte) (dst []byte) {
src = a.padding(src)
dst = make([]byte, len(src))
var index int = 0
for len(src) > 0 {
a.cip.Encrypt(dst[index:index+a.cip.BlockSize()], src)
index += a.cip.BlockSize()
src = src[a.cip.BlockSize():]
}
return dst
}
//使用AES解密文本
func (a *tobytes) Decrypt(src []byte) (dst []byte) {
if len(src)%a.cip.BlockSize() != 0 {
return src
}
dst = make([]byte, len(src))
var index int = 0
for len(src) > 0 {
a.cip.Decrypt(dst[index:index+a.cip.BlockSize()], src)
index += a.cip.BlockSize()
src = src[a.cip.BlockSize():]
}
return a.unpadding(dst)
}
//使用AES加密文本的时候文本必须定长,即必须是16,24,32的整数倍,
func (a *tobytes) padding(src []byte) (dst []byte) {
pdg := a.cip.BlockSize() - len(src)%a.cip.BlockSize()
p := a.pdgtext[:pdg]
p[pdg-1] = byte(pdg)
return append(src, p...)
}
//使用AES解密文本,解密收删除padding的文本
func (a *tobytes) unpadding(src []byte) (dst []byte) {
length := len(src)
if length <= 0 {
return src
}
return src[:(length - int(src[length-1]))]
}