如何基于python3和Vue实现AES数据加密
作者:拐弯 发布时间:2023-08-08 23:47:37
标签:python,Vue,AES,数据,加密
高级加密标准(AES,Advanced Encryption Standard)为最常见的对称加密算法(微信小程序加密传输就是用这个加密算法的)。对称加密算法也就是加密和解密用相同的密钥,具有以下几个特点:
1、最常用的对称加密算法
2、密钥建立时间短、灵敏性好、内存需求低
3、实际使用中,使用工作模式为CTR(最好用BC去实现),此工作模式需要引入IV参数(16位的字节数组)
4、密钥长度128/192/256,其中192与256需要配置无政策限制权限文件(JDK6)
5、填充模式最常用的两种PKCS5Padding和PKCS7Padding,其中后者只有BC独有。
6、加密和解密用到的密钥是相同的,这种加密方式加密速度非常快,适合经常发送数据的场合。
python (ECB)应用
安装:
Windows : pip install pycryptodome
Linux : pip install pycrypto
import base64
import json
import re
from Crypto.Cipher import AES
from Crypto.Util.Padding import pad
class AesCrypt(object):
"""
AES 加密组件
"""
def __init__(self, user, is_json=True):
# 这里的密钥长度必须是 16 24 32
key = 'suiyi_' + user.get('Auth')
self.is_json = is_json
self.encode_ = 'utf-8'
self.key = self.add_32(key)
print(self.key)
self.aes = AES.new(self.key, AES.MODE_ECB) # 创建一个aes对象
def add_32(self, key):
"""
key 补齐32位
:param key:
:return:
"""
# 字符串 a 不要小于32位
a = 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa'
key += a
key = key[0:32]
return key.encode(self.encode_)
def aes_encrypt(self, text):
"""
加密 支持 json 需在实例中制动 is_json = True
:param text:
:return:
"""
if self.is_json:
text = json.dumps(text, ensure_ascii=False)
text = pad(text.encode('utf-8'), AES.block_size, style='pkcs7')
encrypt_text = self.aes.encrypt(text)
return base64.encodebytes(encrypt_text).decode().strip()
def aes_decrypt(self, text):
"""
解密 支持 json 需在实例中制动 is_json = True
:param text:
:return:
"""
text = base64.decodebytes(text.encode(self.encode_))
decrypt_bytes = self.aes.decrypt(text)
decrypt_text = re.compile('[\\x00-\\x08\\x0b-\\x0c\\x0e-\\x1f\n\r\t]').sub('', decrypt_bytes.decode(
self.encode_))
if self.is_json:
decrypt_text = json.loads(decrypt_text)
return decrypt_text
if __name__ == '__main__':
user = {'Auth': '0000_zhangziyi'}
pr = AesCrypt(user, is_json=True)
data = {"unit": 1, "theme": "cur", "look_detail": True, "zero_empty": True, "zero_hide": True, "data_type": "sum"}
en_text = pr.aes_encrypt(data)
print('密文:', en_text)
pr2 = AesCrypt(user, is_json=True)
print('明文:', pr2.aes_decrypt(en_text))
Vue (ECB)应用
安装:
cnpm install crypto-js --save
import store from '@/store'
import CryptoJS from 'crypto-js/crypto-js'
function add_secret_key (userAuth) {
let key = 'suiyi_' + userAuth
if (key.length < 32) {
let a = 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa'
key += a.slice(0, 32 - key.length)
} else if (key.length > 32) {
key = key.slice(0, 32)
}
console.log(key)
return key
}
/**
* 加密
* @param wordimport { aes_encrypt, aes_decrypt } from '../../libs/crypto'
aes_encrypt(this.data)
aes_decrypt(this.AES_data)
* @param userAuth代码
* @param is_json
* @returns {string}
*/
export const aes_encrypt = (word, userAuth, is_json = true) => {
if (is_json) {
word = JSON.stringify(word)
}
var key = CryptoJS.enc.Utf8.parse(add_secret_key(userAuth)) // s/iqSaaE0F3tsLgMCkCZjvqptKKzqD9/pMUnMkCwNjg= Set
var srcs = CryptoJS.enc.Utf8.parse(word)
var encrypted = CryptoJS.AES.encrypt(srcs, key, { mode: CryptoJS.mode.ECB, padding: CryptoJS.pad.Pkcs7 })
return encrypted.toString()
}
/**
* 解密
* @param word
* @param userAuth
* @param is_json
* @returns {string}
*/
export const aes_decrypt = (word, userAuth, is_json = true) => {
var key = CryptoJS.enc.Utf8.parse(add_secret_key(userAuth))// s/iqSaaE0F3tsLgMCkCZjvqptKKzqD9/pMUnMkCwNjg= Set
var decrypt = CryptoJS.AES.decrypt(word, key, { mode: CryptoJS.mode.ECB, padding: CryptoJS.pad.Pkcs7 })
let decrypt_text = CryptoJS.enc.Utf8.stringify(decrypt).toString()
if (is_json) {
decrypt_text = JSON.parse(decrypt_text)
}
return decrypt_text
}
来源:https://www.cnblogs.com/zhang-zi-yi/p/12581138.html
0
投稿
猜你喜欢
- 在一些项目中, 我们会使用json 来将字符串转为结构体,但是很多时候,这种结构体只会用一次,基本上只会用于反序列化, 对于这种只用到一次的
- 起因在公司搭建了套webpack多页面应用脚手架,开始用着很爽,解决了既想使用Vue的模块化开发,又想做多页打包上线管理的初衷,但是随着业务
- SQL Server数据库查询速度慢的原因有很多,常见的有以下几种:1、没有索引或者没有用到索引(这是查询慢最常见的问题,是程序设计的缺陷)
- 下面是虚机维护中,经常碰到的一些ASP程序中的数据库调用的错误,现收集整理如下:
- 本文介绍了可以帮助简化 PHP 开发的10个项目,包括框架,类库,工具,代码。1.CakePHP Development Framework
- 1.1全部php生成结构1.2html中嵌套php总结如下:html和php混写规则:php代码必须包在<?php ?>html
- 他们是如何不让我的Teleport和Webzip工作的?你也可以做得到哦: <%dim UserAgentUser
- 在当前的Web设计中,jQuery被越来越多地应用在Web开发中,之所以jQuery收到如此程度的欢迎,除了其本身具备的优秀易读易操作的代码
- 1.如果有ID字段,就是具有唯一性的字段 代码如下:delect table where id not in ( select max(id
- 南京的炎炎夏日也未能挡住书友会朋友们的参与,下午两点半我们正式开始了这个月的话题:“浏览器”。一开始大家大致上说了一些自己认为各浏览器中各自
- 判断字符串长度函数:<SCRIPT LANGUAGE="JavaScript"><!--fu
- 今天是五一劳动节,可是我们劳动人民的节日哦。很多大网站都设计了特殊的logo来表示向每一位普通的劳动者致敬!下面就让我们看看这些logo吧!
- 1.因为oracle 10g暂时没有与win7兼容的版本,我们可以通过对安装软件中某些文件的修改达到安装的目地。 a)打开“\ORACLE1
- 希望这是window.open()打开fullscreen全屏窗口时无提示关闭父窗口的完美解决方案:我们通常都是用控件法,在父窗口文件里放一
- 接着上一篇,统一思想,遵循标准。如何遵循标准,其实标准有很多,结构标准,表现标准,行为标准。选择标准规范,就优先选择W3C推荐的标准。结构标
- create or replace PROCEDURE proceudre_name AS BEGIN DECLARE sPara VARC
- 最近刚接触了公司的服务器,使用的是Windows 2003 server + IIS 6.0 服务器,在使用无组件上传文件时产生这个错误时:
- 1,filesize()函数返回错误的值。 使用curl将某个页面下载到本地时,需要将下载到的临时文件tmpHtml.txt的内容读取到一个
- 为了防止网络上日益猖獗的垃圾广告和灌水评论,大多数网站在信息发布的时候要求输入验证码。图片、文字、字母甚至还有计算题。验证码图片里的信息东颠
- 首先我的环境已配置好:GO的目录结构是:add.gopackage calc//函数名必须大写首字母,不然外部包找不到func Add(a