新聞中心
1、python中使用Base64加密:

成都創(chuàng)新互聯(lián)擁有一支富有激情的企業(yè)網(wǎng)站制作團(tuán)隊(duì),在互聯(lián)網(wǎng)網(wǎng)站建設(shè)行業(yè)深耕10余年,專業(yè)且經(jīng)驗(yàn)豐富。10余年網(wǎng)站優(yōu)化營銷經(jīng)驗(yàn),我們已為數(shù)千家中小企業(yè)提供了網(wǎng)站建設(shè)、成都做網(wǎng)站解決方案,按需規(guī)劃網(wǎng)站,設(shè)計(jì)滿意,售后服務(wù)無憂。所有客戶皆提供一年免費(fèi)網(wǎng)站維護(hù)!
Python內(nèi)置的base64模塊可以直接進(jìn)行base64的編解碼
注意:用于base64編碼的,要么是ASCII包含的字符,要么是二進(jìn)制數(shù)據(jù)
# -*- 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模塊進(jìn)行md5操作
# -*- coding:UTF-8 -*-
__author__ = 'rxz'
import hashlib
# 待加密信息
str = '中國你好'
# 創(chuàng)建md5對象,
#md5對象,md5不能反解,但是加密是固定的,就是關(guān)系是一一對應(yīng),所以有缺陷,可以被對撞出來
hl = hashlib.md5()
#要對哪個字符串進(jìn)行加密,就放這里
# 此處必須聲明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'))
'''
如果沒有參數(shù),所以md5遵守一個規(guī)則,生成同一個對應(yīng)關(guān)系,如果加了參數(shù),
就是在原先加密的基礎(chǔ)上再加密一層,這樣的話參數(shù)只有自己知道,防止被撞庫,
因?yàn)閯e人永遠(yuǎn)拿不到這個參數(shù)
'''
hash3 .update(bytes("admin",encoding = "utf-8"))
print(hash3.hexdigest()) #9aea3c0a6c51555c1a4d0a5e9b689ded3、使用hmac加密
python中還有一個hmac模塊,它對我們創(chuàng)建key和內(nèi)容再進(jìn)行處理然后再加密
該模塊加密是先把數(shù)據(jù)存儲到字典中,然后再進(jìn)行加密,方法與上述方法類似。
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
"""注:加密數(shù)據(jù)時一定要指定數(shù)據(jù)編碼格式。
4、使用sha1 加密
SHA1的全稱是Secure Hash Algorithm(安全哈希算法) 。SHA1基于MD5,加密后的數(shù)據(jù)長度更長,
它對長度小于264的輸入,產(chǎn)生長度為160bit的散列值。比MD5多32位。
因此,比MD5更加安全,但SHA1的運(yùn)算速度就比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
"""推薦學(xué)習(xí)《Python教程》。
文章題目:創(chuàng)新互聯(lián)Python教程:python中如何實(shí)現(xiàn)加密
URL地址:http://www.fisionsoft.com.cn/article/cdceigg.html


咨詢
建站咨詢
