• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

Python 常见加密操作的实现

python 搞代码 4年前 (2022-01-07) 37次浏览 已收录 0个评论
文章目录[隐藏]

这篇文章主要介绍了Python 常见加密操作的实现,帮助大家更好的理解和学习使用python,感兴趣的朋友可以了解下

hashlib加密

 import hashlib   # 有很多种加密方式,md5,sha1等等 h = hashlib.md5() # 提交加密的内容,bytes形式 h.update(b"satori") # 二进制形式 print(h.digest()) ''' b'\x13\xd54\x0f:\xdf\x8e[\xe0\x83\xdd\xc6\xca\xd2G\xb8' ''' # 十六进制形式 print(h.hexdigest()) ''' 13d5340f3adf8e5be083ddc6cad247b8 '''
 import hashlib   # 相对的,还有简便的操作 # 直接指定要加密的字符串 h1 = hashlib.md5(b"satori") print(h1.hexdigest()) ''' 13d5340f3adf8e5be083ddc6cad247b8 '''   h2 = hashlib.md5() h2.update(b"satori") print(h2.hexdigest()) ''' 13d5340f3adf8e5be083ddc6cad247b8 ''' # 两者结果是一样的

hmac加密

 import hmac import hashlib   # key:密钥 # msg:内容 # digestmod:加密的模式,默认是md5 h1 = hmac.new(key=b"satori", msg=b"satori", digestmod=hashlib.md5) print(h1.hexdigest()) ''' 3cba321fbb4e02c5b7e9fb7ef82bb47b '''   # 也可以通过update添加内容,是添加,不是覆盖 h2 = hmac.new(key=b"satori") h2.update(b"satori") print(h2.hexdigest()) ''' 3cba321fbb4e02c5b7e9fb7ef82bb47b '''

secrets

 import secrets   # secrets貌似是python3.6里新增的模块,先来看看api # secrets.choice(iterable),从可迭代对象里随机选择一个元素并返回 # secrets.randbelow(n),从[0,n)中随机选择一个数并返回 # secrets.randbits(k),返回带有k个随机位的整数 # secrets.token_bytes(nbytes=None),返回一个包含n个bytes的随机字符串 # secrets.token_hex(nbytes=None),返回一个包含n个bytes的16进制随机文本字符串,每个字节转换成两个16进制数字,一般用来生成随即密码 # secrets.token_urlsafe(nbytes=None),返回一个包含n个bytes的随即url字符串,可以用来生成一个临时的随机令牌 # secrets.compare_digest(a, b),比较两个字符串是否相等   print(secrets.choice("古明地盆"))  # 古 print(secrets.choice(["satori", "mashiro", "nagisa"]))  # nagisa # 和random.choice()是类似的   print(secrets.randbelow(8))  # 6 # 和random.randint()类似,但是secrets.randbelow()只能默认从零开始,且不包含右端点   print(secrets.randbits(7))  # 96   print(secrets.token_byt<b style="color:transparent">来源gao@!dai!ma.com搞$$代^@码!网</b>es())  # b'\x87\x98\x1c\x80TO\xcf\x82\xc9\xf1\xd6\xf6f\xd7\xd7\xae\xea.\xfd0y\xd6\xaf\xfbe\xb4v\x8b@\xc8t\xe6' print(secrets.token_bytes(nbytes=20))  # b'\xa5:(\xf2\xcb\xb2\xd8\xbce\xacn\x8c\x95\x05:\x07e#\xa7M'   print(secrets.token_hex())  # 0904e492deaab1270f11671d687f3bb2c7ead5283bfe55a3b51e560101c38828 print(secrets.token_hex(20))  # 851801ed1367bc946b1f28812a83a7e84d91908e   print(secrets.token_urlsafe())  # sGGhrL8VLECMYalQ5DHMDm0yugoVsr2M-SvN4z2Qk8k print(secrets.token_urlsafe(nbytes=20))  # PIvP0VoRxvfignT1MH_p2vNog9U

base64

 import base64   s = bytes("古明地盆", encoding="utf-8")   en_data1 = base64.b64encode(s) print(en_data1)  # b'5Y+k5piO5Zyw55uG' de_data1 = base64.b64decode(en_data1) print(str(de_data1, encoding="utf-8"))  # 古明地盆   # 可以看出来,是为了考虑url安全的一种加密方式 # 与普通的b64encode不同的是,会将一些字符进行一个替换 en_data2 = base64.urlsafe_b64encode(s) print(en_data2)  # b'5Y-k5piO5Zyw55uG' de_data2 = base64.urlsafe_b64decode(en_data2) print(str(de_data2, encoding="utf-8"))  # 古明地盆

cryptography

 from cryptography.fernet import Fernet   # 生成秘钥cipher_key cipher_key = Fernet.generate_key()   # 传入秘钥实例化一个类 cipher = Fernet(cipher_key)   text = '古明地觉'.encode("utf-8")   #进行加密 encrypted_text = cipher.encrypt(text) print(type(encrypted_text))  #    #进行解密 decrypted_text = cipher.decrypt(encrypted_text) print(decrypted_text.decode("utf-8"))  # 古明地觉

以上就是Python 常见加密操作的实现的详细内容,更多关于python 加密操作的资料请关注gaodaima搞代码网其它相关文章!

以上就是Python 常见加密操作的实现的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:Python 常见加密操作的实现
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址