今天在用Golang解析php那边用Aes加密的一个key。网上大多是用base64将结果编码一下。而且用到了向量。我php

那边没有用到向量。所以golang这边也是要去掉的。参考网站的改了下。能够和php通用。

另外,需要注意的是加密的key只能是16,24,32.分别对应的是AES-128,AES-192,AES-256等

package main

import (

​	"bytes"

​	"crypto/aes"

​	"crypto/cipher"

​	"encoding/base64"

​	"encoding/hex"

​	"errors"

​	"fmt"

)

//填充

func pad(src []byte) []byte {

​	padding := aes.BlockSize - len(src)%aes.BlockSize

​	padtext := bytes.Repeat([]byte{byte(padding)}, padding)

​	return append(src, padtext...)

}

func unpad(src []byte) ([]byte, error) {

​	length := len(src)

​	unpadding := int(src[length-1])

​	if unpadding > length {

​		return nil, errors.New("unpad error. This could happen when incorrect encryption key is used")

​	}

​	return src[:(length - unpadding)], nil

}

func encrypt(key []byte, text string) (string, error) {

​	block, err := aes.NewCipher(key)

​	if err != nil {

​		return "", err

​	}

​	msg := pad([]byte(text))

​	ciphertext := make([]byte, aes.BlockSize+len(msg))

​	//没有向量,用的空切片

​	iv := make([]byte,aes.BlockSize)

​	mode := cipher.NewCBCEncrypter(block, iv)

​	mode.CryptBlocks(ciphertext[aes.BlockSize:], msg)

​	finalMsg := (base64.StdEncoding.EncodeToString(ciphertext))

​	fmt.Println(hex.EncodeToString([]byte(ciphertext[aes.BlockSize:])))

​	return finalMsg, nil

}

func decrypt(key []byte, text string) (string, error) {

​	block, err := aes.NewCipher(key)

​	if err != nil {

​		return "", err

​	}

​	decodedMsg,_ := hex.DecodeString(text)

​	iv  :=make([]byte,aes.BlockSize)

​	msg := decodedMsg

​	mode := cipher.NewCBCDecrypter(block, iv)

​	mode.CryptBlocks(msg,msg)

​	unpadMsg, err := unpad(msg)

​	if err != nil {

​		return "", err

​	}

​	return string(unpadMsg), nil

}

func main() {

​	key := []byte("0123456789abcdef")

​	encryptText, _ := encrypt(key, "123456")

​	rawText, err := decrypt(key, "2994dc19badcd3e820065f4f8211f584")

​	fmt.Println("text %s \n", rawText)

}

Golang中,Aes加解密的更多相关文章

  1. 关于java php go 中AES加解密秘钥长度问题

    今天心血来朝,想用go把php中的一个小功能重写一下,但在解密aes加密的数据时碰到了个坑! php的mcrypt拓展(貌似php7.1版本以上不支持了)提供了aes的加解密: 而且php aes 的 ...

  2. .Net Core AES加解密

    项目中token在传输过程中采用了AES加密,  网上找到的两篇博文都有写问题,在这里记录一下.Net Core 2.2代码中AES加解密的使用: //AES加密 传入,要加密的串和, 解密key p ...

  3. AES加解密算法在Android中的应用及Android4.2以上版本调用问题

     from://http://blog.csdn.net/xinzheng_wang/article/details/9159969 AES加解密算法在Android中的应用及Android4.2以上 ...

  4. Java中的AES加解密工具类:AESUtils

    本人手写已测试,大家可以参考使用 package com.mirana.frame.utils.encrypt; import com.mirana.frame.constants.SysConsta ...

  5. C#与java中的AES加解密互解算法

    一.C#版AES加解密算法 public class AESCode { public string Key { get; set; } public string Encrypt(string va ...

  6. DES,AeS加解密,MD5,SHA加密

    1.DES一共就有4个参数参与运作:明文.密文.密钥.向量.其中这4者的关系可以理解为: 密文=明文+密钥+向量: 明文=密文-密钥-向量: 为什么要向量这个参数呢?因为如果有一篇文章,有几个词重复, ...

  7. c# Aes加解密和对象序列化

    aes加解密 public class AesCryptto { private string key = "hjyf57468jhmuist"; private string i ...

  8. AES加解密算法Qt实现

    [声明] (1) 本文源码 在一位未署名网友源码基础上,利用Qt编程,实现了AES加解密算法,并添加了文件加解密功能.在此表示感谢!该源码仅供学习交流,请勿用于商业目的. (2) 图片及描述 除图1外 ...

  9. aes加解密 Illegal key size

    做aes加密时,发生一个奇怪的错误,在本地环境是好的,发布到测试环境就出问题, java.security.InvalidKeyException: Illegal key size 想到本地环境之前 ...

随机推荐

  1. Linux CentOs基本命令

    基本操作(命令模式下) yy --复制光标所在行 nyy --n为数字,复制光标所在向下n行 p --粘贴到光标的下一行 P --贴在光标的上一行 G --光标移到文件末尾 gg --光标移到文件头 ...

  2. @TableField(select=false)

    使用这个注解排除删除标识字段.

  3. 201871010124-王生涛《面向对象程序设计(java)》第十三周学习总结

    项目 内容 这个作业属于哪个课程 <任课教师博客主页链接>https://www.cnblogs.com/nwnu-daizh/ 这个作业的要求在哪里 <作业链接地址>http ...

  4. android onActivityResult不被回调或窗体弹出后即补回调的解决办法

    假设从A窗体弹出B窗体,则在AndroidManifest.xml文件中,B不能有:android:launchMode="singleTask“属性,否则,A窗体里的onActivityR ...

  5. vs在matlab生成的dll中,load treebigger错误

    提示的错误:Warning: Variable 'model' originally saved as a TreeBagger cannot be instantiated as an object ...

  6. Vue (表单、斗篷、条件、循环指令,分隔符成员、计算属性成员、属性的监听、vue组件、子组件、各个常见的钩子函数)

    表单指令 <!DOCTYPE html> <html lang="zh"> <head> <meta charset="UTF- ...

  7. shell的变量以及常见符号

    shell的变量以及常见符号 常见变量 不同于其它语言需要先声明变量,shell的变量直接使用 eg:      a=15 调用变量的话 $a 或者 ${a} $? #判断上一条命令执行的是否成功 0 ...

  8. Flask-Login中装饰器@login_manager.user_loader的作用及原理

    Flask-Login通过装饰器@login_required来检查访问视图函数的用户是否已登录,没有登录时会跳转到login_manager.login_view = 'auth.login'所注册 ...

  9. RaxML使用

    1.下载 https://github.com/stamatak/standard-RAxML 2.How many Threads shall I use? 重要的是要知道,RAxML PThrea ...

  10. DNS用的是TCP协议还是UDP协议

    DNS占用53号端口,同时使用TCP和UDP协议.那么DNS在什么情况下使用这两种协议? DNS在区域传输的时候使用TCP协议,其他时候使用UDP协议. DNS区域传输的时候使用TCP协议: 1.辅域 ...