用python的哈希函數(shù)對密碼加密
今天我將教大家如何用哈希函數(shù)將密碼加密
加密后的密碼是很難倒推的~
普通加密:
首先調用函數(shù)hashlib
import hashlib
然后使用哈希函數(shù)對密碼進行加密
這里我使用sha256進行加密
再造一個密碼出來
password = 'wotemo666'
接著用哈希函數(shù)對它進行加密
注意:這里要使用encode對password進行編碼格式聲明,不然會報錯

hash_password = hashlib.sha256(password.encode("utf-8")).hexdigest()
print(hash_password)運行這行代碼輸出的就是加密后的哈希值啦?。?!

圖中這行字符串就是 ‘wotemo666’ 對應的哈希值
每個明文對應一個哈希值,但一個哈希值卻對應無數(shù)個明文
這就導致哈希值是不可逆的,這樣,你的密碼就更加安全啦~
下面是完整的代碼
# 首先調用函數(shù)hashlib
import hashlib
# 再造一個密碼出來
password = 'wotemo666'
# 用sha256對password進行加密
hash_password = hashlib.sha256(password.encode("utf-8")).hexdigest()
# 輸出對應的哈希值
print(hash_password)
進階加密:
如果想讓你的密碼更加的安全,那就要給你的密碼加點鹽了
這里的加鹽就是指在明文密碼前或后插入一段隨機字符串,然后再進行哈希加密
這樣得出來的哈希值就更加的復雜,就更不容易被破解啦
下面我們來實現(xiàn)吧
首先調用random函數(shù)隨機生成“鹽”
import random
這里我們要用到python中的string模塊生成a ~ Z和0 ~ 9的所有字符
調用string模塊
import string
String模塊中的常量:
string.digits:數(shù)字0~9
string.ascii_letters:所有字母(大小寫)
string.lowercase:所有小寫字母
string.printable:可打印字符的字符串
string.punctuation:所有標點
string.uppercase:所有大寫字母
這里我們只需用到前兩個digits和ascii_letters就可以了
ps:如果想密碼更復雜一些可以使用punctuation生成所有標點,然后一同加入到鹽中去
這里我們使用while和random函數(shù)隨機生成可以控制長度的鹽
先創(chuàng)建一個激活while的變量和一個儲存鹽的空白字符串
active = 0 salts = ''
接著用while生成鹽
while active < 10:
# 用active激活while
# 這里生成了一個長度為20的鹽
# 想要生成多長的鹽,就將示例中的10改為期望長度的一半
# 但這里的值最好是整數(shù)
salt_one = random.choice(string.digits)
# salt_one生成一個隨機的數(shù)字
salt_two = random.choice(string.ascii_letters)
# salt_two生成一個隨機的字母(區(qū)分大小寫)
salt = salt_one + salt_two
#salt是它們的加和,這也就是為什么前面要減半
salts += salt
# 然后將加和后的值附加到剛才創(chuàng)建的空白字符串中
active += 1
# while函數(shù)基本用法我就不多說了
這樣鹽就生成出來啦,如圖:

接下來,我們將鹽附加到明文密碼上
after_salt_password = salts + password # 鹽的前后順序無所謂,password為你的密碼
然后,我們再調用hashlib生成哈希值
這里的操作就和前面的一模一樣了,唯一不同的是密碼加鹽了
# 首先調用函數(shù)hashlib
import hashlib
# 再造一個密碼出來
password = 'wotemo666'
# 然后加鹽
after_salt_password = salts + password
# 用sha256對password進行加密
hash_password = hashlib.sha256(after_salt_password.encode("utf-8")).hexdigest()
加鹽后的哈希值就更為復雜了

下面是完整的代碼
# 調用random, string, hashlib函數(shù)
import random
import string
import hashlib
# 初始化
active = 0
salts = ''
while active < 10:
# 用active激活while
# 這里生成了一個長度為20的鹽
# 想要生成多長的鹽,就將示例中的10改為期望長度的一半
# 但這里的值最好是整數(shù)
salt_one = random.choice(string.digits)
# salt_one生成一個隨機的數(shù)字
salt_two = random.choice(string.ascii_letters)
# salt_two生成一個隨機的字母(區(qū)分大小寫)
salt = salt_one + salt_two
#salt是它們的加和,這也就是為什么前面要減半
salts += salt
# 然后將加和后的值附加到剛才創(chuàng)建的空白字符串中
active += 1
# while函數(shù)基本用法我就不多說了
password = 'wotemo666'
# 然后加鹽
after_salt_password = salts + password
# 用sha256對password進行加密
hash_password = hashlib.sha256(after_salt_password.encode("utf-8")).hexdigest()
# hash_password就是輸出的哈希值
print(hash_password)
你學會了嗎?
到此這篇關于用python的哈希函數(shù)對密碼加密的文章就介紹到這了,更多相關python哈希函數(shù)加密內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
python使用OS模塊操作系統(tǒng)接口及常用功能詳解
os是?Python?標準庫中的一個模塊,提供了與操作系統(tǒng)交互的功能,在本節(jié)中,我們將介紹os模塊的一些常用功能,并通過實例代碼詳細講解每個知識點2023-06-06
Python Tornado之跨域請求與Options請求方式
這篇文章主要介紹了Python Tornado之跨域請求與Options請求方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-03-03
Python Unittest ddt數(shù)據(jù)驅動的實現(xiàn)
本文主要介紹了Python Unittest ddt數(shù)據(jù)驅動的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-02-02
Python實現(xiàn)備份MySQL數(shù)據(jù)庫的方法示例
這篇文章主要介紹了Python實現(xiàn)備份MySQL數(shù)據(jù)庫的方法,涉及Python針對mysql數(shù)據(jù)庫的連接及基于mysqldump命令操作數(shù)據(jù)庫備份的相關實現(xiàn)技巧,需要的朋友可以參考下2018-01-01
Python設置Socket代理及實現(xiàn)遠程攝像頭控制的例子
這篇文章主要介紹了Python設置Socket代理及實現(xiàn)遠程攝像頭控制的例子,皆是對socket模塊的實際運用,需要的朋友可以參考下2015-11-11

