知行编程网知行编程网  2022-12-23 14:30 知行编程网 隐藏边栏  8 
文章评分 0 次,平均分 0.0
导语: 本文主要介绍了关于python中如何实现加密的相关知识,希望可以帮到处于编程学习途中的小伙伴

如何在python中实现加密

1、Python中使用Base64加密:

Python内置的base64模块可以直接进行base64的编解码

注意:对于base64编码,要么ASCII包含字符要么二进制数据

 # -*- coding:UTF-8 -*-
__author__ = 'rxz'
import base64
 
a = base64.b64encode(b"hello world")
print(a) #  b'aGVsbG8gd29ybGQ='
 
b = base64.b64decode(a)
print(b) # b"hello world"

2、Python中使用MD5加密

由于MD5模块在python3中被移除,在python3中使用hashlib模块进行md5操作

 # -*- coding:UTF-8 -*-
__author__ = 'rxz'
import hashlib
 
# 待加密信息
str = '中国你好'
 
# 创建md5对象,
#md5对象,md5不能反解,但是加密是固定的,就是关系是一一对应,所以有缺陷,可以被对撞出来
hl = hashlib.md5()
 
#要对哪个字符串进行加密,就放这里
# 此处必须声明encode
# 若写法为hl.update(str)  报错为: Unicode-objects must be encoded before hashing
hl.update(str.encode(encoding='utf-8'))
 
print('MD5加密前为 :' + str)
#hl.hexdigest()) #拿到加密字符串
print('MD5加密后为 :' + hl.hexdigest())
 
"""
MD5加密前为 :中国你好
MD5加密后为 :560a6b11a85d436acfa4bd7f34462f40
"""
 
hash3 = hashlib.md5(bytes('abd',encoding='utf-8'))
''' 
如果没有参数,所以md5遵守一个规则,生成同一个对应关系,如果加了参数,
就是在原先加密的基础上再加密一层,这样的话参数只有自己知道,防止被撞库,
因为别人永远拿不到这个参数
'''
hash3 .update(bytes("admin",encoding = "utf-8"))
print(hash3.hexdigest()) #9aea3c0a6c51555c1a4d0a5e9b689ded

3、使用hmac加密

python中还有一个hmac模块,创建key和内容供我们处理然后加密

本模块的加密是先将数据存储在字典中,再进行加密,方法与上述方法类似。

import hmac
 
 
hm = hmac.new(b'abc')
hm = hmac.new('中国你好'.encode(encoding='utf-8'),b'bads')
print(hm.digest())
print(hm.hexdigest())
 
"""
b'\xc8;\x0c\x0b\xd42\xc37\xd0X\xbc\xfbf=RP'
c83b0c0bd432c337d058bcfb663d5250
"""

注:加密数据时一定要指定数据编码格式。

4、使用sha1 加密

SHA1的全称是Secure Hash Algorithm(安全散列算法)。 SHA1基于MD5,加密数据长度更长。

它为长度小于264的输入产生一个长度为160位的散列值。比MD5多32位。

因此,比MD5更加安全,但SHA1的运算速度就比MD5要慢了。

 # -*- coding:UTF-8 -*-
__author__ = 'rxz'
import hashlib
 
str = "中国你好"
a = hashlib.sha1(str.encode("utf-8")).hexdigest()
print("sha1加密前为 :",str)
print("sha1加密前后 :",a)
 
"""
sha1加密前为 : 中国你好
sha1加密前后 : 3e6c570876775d0031dbf66247ed1054d4ef695e
"""

推荐学习《
》。

本文为原创文章,版权归所有,欢迎分享本文,转载请保留出处!

知行编程网
知行编程网 关注:1    粉丝:1
这个人很懒,什么都没写
扫一扫二维码分享