日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學(xué)無先后,達(dá)者為師

網(wǎng)站首頁 編程語言 正文

用python的哈希函數(shù)對密碼加密_python

作者:沃特陌 ? 更新時間: 2022-04-11 編程語言

今天我將教大家如何用哈希函數(shù)將密碼加密
加密后的密碼是很難倒推的~

普通加密:

首先調(diào)用函數(shù)hashlib

import hashlib

然后使用哈希函數(shù)對密碼進(jìn)行加密
這里我使用sha256進(jìn)行加密

再造一個密碼出來

password = 'wotemo666'

接著用哈希函數(shù)對它進(jìn)行加密

注意:這里要使用encode對password進(jìn)行編碼格式聲明,不然會報錯

未聲明編碼格式報錯

hash_password = hashlib.sha256(password.encode("utf-8")).hexdigest()
print(hash_password)

運(yùn)行這行代碼輸出的就是加密后的哈希值啦!!!

哈希值輸出

圖中這行字符串就是 ‘wotemo666’ 對應(yīng)的哈希值

每個明文對應(yīng)一個哈希值,但一個哈希值卻對應(yīng)無數(shù)個明文
這就導(dǎo)致哈希值是不可逆的,這樣,你的密碼就更加安全啦~

下面是完整的代碼

# 首先調(diào)用函數(shù)hashlib
import hashlib
# 再造一個密碼出來
password = 'wotemo666'
# 用sha256對password進(jìn)行加密
hash_password = hashlib.sha256(password.encode("utf-8")).hexdigest()
# 輸出對應(yīng)的哈希值
print(hash_password)

進(jìn)階加密:

如果想讓你的密碼更加的安全,那就要給你的密碼加點(diǎn)鹽

這里的加鹽就是指在明文密碼前或后插入一段隨機(jī)字符串,然后再進(jìn)行哈希加密

這樣得出來的哈希值就更加的復(fù)雜,就更不容易被破解啦

下面我們來實(shí)現(xiàn)吧

首先調(diào)用random函數(shù)隨機(jī)生成“鹽”

import random

這里我們要用到python中的string模塊生成a ~ Z和0 ~ 9的所有字符

調(diào)用string模塊

import string

String模塊中的常量:

string.digits:數(shù)字0~9

string.ascii_letters:所有字母(大小寫)

string.lowercase:所有小寫字母

string.printable:可打印字符的字符串

string.punctuation:所有標(biāo)點(diǎn)

string.uppercase:所有大寫字母

這里我們只需用到前兩個digits和ascii_letters就可以了

ps:如果想密碼更復(fù)雜一些可以使用punctuation生成所有標(biāo)點(diǎn),然后一同加入到鹽中去

這里我們使用while和random函數(shù)隨機(jī)生成可以控制長度的鹽

先創(chuàng)建一個激活while的變量和一個儲存鹽的空白字符串

active = 0
salts = ''

接著用while生成鹽

 while active < 10:
        # 用active激活while
        # 這里生成了一個長度為20的鹽
        # 想要生成多長的鹽,就將示例中的10改為期望長度的一半
        # 但這里的值最好是整數(shù)
        salt_one = random.choice(string.digits)
        # salt_one生成一個隨機(jī)的數(shù)字
        salt_two = random.choice(string.ascii_letters)
        # salt_two生成一個隨機(jī)的字母(區(qū)分大小寫)
        salt = salt_one + salt_two
        #salt是它們的加和,這也就是為什么前面要減半
        salts += salt
        # 然后將加和后的值附加到剛才創(chuàng)建的空白字符串中
        active += 1
        # while函數(shù)基本用法我就不多說了

這樣鹽就生成出來啦,如圖:

生成鹽的值

接下來,我們將鹽附加到明文密碼上

after_salt_password = salts + password
# 鹽的前后順序無所謂,password為你的密碼

然后,我們再調(diào)用hashlib生成哈希值

這里的操作就和前面的一模一樣了,唯一不同的是密碼加鹽了

# 首先調(diào)用函數(shù)hashlib
import hashlib
# 再造一個密碼出來
password = 'wotemo666'
# 然后加鹽
after_salt_password = salts + password
# 用sha256對password進(jìn)行加密
hash_password = hashlib.sha256(after_salt_password.encode("utf-8")).hexdigest()

加鹽后的哈希值就更為復(fù)雜了

加鹽后的哈希值

下面是完整的代碼

# 調(diào)用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生成一個隨機(jī)的數(shù)字
        salt_two = random.choice(string.ascii_letters)
        # salt_two生成一個隨機(jī)的字母(區(qū)分大小寫)
        salt = salt_one + salt_two
        #salt是它們的加和,這也就是為什么前面要減半
        salts += salt
        # 然后將加和后的值附加到剛才創(chuàng)建的空白字符串中
        active += 1
        # while函數(shù)基本用法我就不多說了

password = 'wotemo666'
# 然后加鹽
after_salt_password = salts + password
# 用sha256對password進(jìn)行加密
hash_password = hashlib.sha256(after_salt_password.encode("utf-8")).hexdigest()
# hash_password就是輸出的哈希值
print(hash_password)

你學(xué)會了嗎?

原文鏈接:https://blog.csdn.net/shr105/article/details/122799672

欄目分類
最近更新