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

學無先后,達者為師

網站首頁 編程語言 正文

用python的哈希函數對密碼加密_python

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

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

普通加密:

首先調用函數hashlib

import hashlib

然后使用哈希函數對密碼進行加密
這里我使用sha256進行加密

再造一個密碼出來

password = 'wotemo666'

接著用哈希函數對它進行加密

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

未聲明編碼格式報錯

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

運行這行代碼輸出的就是加密后的哈希值啦!!!

哈希值輸出

圖中這行字符串就是 ‘wotemo666’ 對應的哈希值

每個明文對應一個哈希值,但一個哈希值卻對應無數個明文
這就導致哈希值是不可逆的,這樣,你的密碼就更加安全啦~

下面是完整的代碼

# 首先調用函數hashlib
import hashlib
# 再造一個密碼出來
password = 'wotemo666'
# 用sha256對password進行加密
hash_password = hashlib.sha256(password.encode("utf-8")).hexdigest()
# 輸出對應的哈希值
print(hash_password)

進階加密:

如果想讓你的密碼更加的安全,那就要給你的密碼加點鹽

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

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

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

首先調用random函數隨機生成“鹽”

import random

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

調用string模塊

import string

String模塊中的常量:

string.digits:數字0~9

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

string.lowercase:所有小寫字母

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

string.punctuation:所有標點

string.uppercase:所有大寫字母

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

ps:如果想密碼更復雜一些可以使用punctuation生成所有標點,然后一同加入到鹽中去

這里我們使用while和random函數隨機生成可以控制長度的鹽

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

active = 0
salts = ''

接著用while生成鹽

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

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

生成鹽的值

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

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

然后,我們再調用hashlib生成哈希值

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

# 首先調用函數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函數
import random
import string
import hashlib

# 初始化
active = 0
salts = ''

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

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)

你學會了嗎?

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

欄目分類
最近更新