JS-常见编码和加密方式

base64

特征:结尾可能有"=="号

编码
# 想将字符串转编码成base64,要先将字符串转换成二进制数据
url = "https://www.cnblogs.com/songzhixue/"
bytes_url = url.encode("utf-8")
str_url = base64.b64encode(bytes_url)  # 被编码的参数必须是二进制数据
print(str_url)
b'aHR0cHM6Ly93d3cuY25ibG9ncy5jb20vc29uZ3poaXh1ZS8='

解码
# 将base64解码成字符串
import base64
url = "aHR0cHM6Ly93d3cuY25ibG9ncy5jb20vc29uZ3poaXh1ZS8="
str_url = base64.b64decode(url).decode("utf-8")
print(str_url)

'https://www.cnblogs.com/songzhixue/'

Md5

注意:md5是哈希,不是加密
特征:32位


1.编码
md = hashlib.md5()   #  加密,不可逆
md.update('hello'.encode('utf-8'))   # 往对象里传数据加密  ,update只能接受bytes类型
md.update(b'hello')
print(md.hexdigest())
结果:23b431acfeb41e15d466d75de822307c


编码加盐
2.加盐  :自己添加的东西和客户的真密码一起加密,自己添加的东西可以是动态的
md = hashlib.md5()
md.update(b'yan.com')
md.update(b'hello')   # 加密
print(md.hexdigest())  # 获取密文

AES

特征:对称加密,加密解密用的是同样的密钥。对称加密是最快速、最简单的一种加密方式
对称加密:适合经常发送数据的场合
非对称加密:加密和解密用的密钥是不同的,通常加密解密的速度比较慢,适合偶尔发送数据的场合。优点是密钥传输方便。

pythonAES加解密

AES的三要素

密钥:128、192、256
填充:
	NoPadding
	PKCS7Padding
	ZeroPadding
	AnsiX923
	lso10126
	lso97971
	
工作模式:
	CBC、ECB、CTR、CFB、OFB

AES工作模式区别

工作模式:
	CBC、ECB、CTR、CFB、OFB
ECB模式:
	1、简单
	2、有利于计算
	3、相同的明文块经过加密会变成相同的密文块,因此安全性较差
CBC模式:
	1、无法并行计算,性能上不如ECB
	2、引入初始化向量IV,增加复杂度。
	3、安全性高

AES的加密流程

1、把明文按照128bit拆分成若干个明文块
2、按照选择的填充模式来填充最后一个明文块
3、每个明文块利用AES加密器和密钥,加密成密文块

JS-AES、base64、SHA256、RSA等加解密库

利用nodejs中的crypto-js库

var CryptoJS = require("crypto-js")
CryptoJS.AES.encrypt(text,CryptoJS.enc.UTF8.parse(key),data={})

AES的特点、特征

1、有iv的是特征的是CBC工作模式
2、mode和padding标示的加密模式、填充方式
iv:初始向量
mode:工作模式
padding:填充方式

Ascii码

Ascii码是一种特定的编码方式,流行于欧洲国家,表达128常见的字符与操作符,表达力有限

DES

DES全称为Data Encryption Standard,即数据加密标准,是一种使用密钥加密的块算法,1977年被美国联邦政府的国家标准局确定为联邦资料处理标准(FIPS),并授权在非密级政府通信中使用,随后该算法在国际上广泛流传开来。需要注意的是,在某些文献中,作为算法的DES称为数据加密算法(Data Encryption Algorithm,DEA),已与作为标准的DES区分开来。
posted @ 2020-09-23 11:52  Jeff的技术栈  阅读(1244)  评论(0编辑  收藏  举报
回顶部