你在Python中做过最酷的程序是什么?

你在Python中做过最酷的程序是什么?

我做过的最酷的Python程序是Python密码哈希器。首先让我们了解一下什么是Python密码哈希。

阅读更多:Python 教程

什么是密码哈希?

Python密码哈希是一种先进的加密形式,可以用于安全存储在线密码。在今天的网络时代,用户密码是最容易受到攻击的敏感信息之一。密码字符串使用不同的哈希算法转换为一串随机字符,在我的程序中使用了这些算法。用户被指示输入密码字符串,然后选择要使用的哈希算法。然后显示输出哈希,可以在线存储。

使用的步骤

  • 创建不同哈希方法的函数

  • 输入用户的密码字符串

  • 输入用户选择的哈希方法

  • 转换字符串并提供输出

步骤1:创建不同哈希方法的函数

首先,我们创建不同的函数,将密码字符串作为参数并将其转换成密文形式。密文是数据在被哈希后的形式。这些不同的函数包含不同的哈希算法。

语法

def hash_with_MD5(message):
   print ("MD5:", hashlib.md5(message).hexdigest()) 

这里的函数以消息作为参数,并使用MD5哈希算法将其转换为密文。然后,哈希摘要被打印出来。如果使用其他哈希算法,则语法相同,只需更改调用哈希函数的方法。

算法

步骤1 :为不同的哈希算法定义不同的函数

步骤2 :使用函数的参数为用户提供输入的字符串

步骤3 :在函数体中,打印哈希密码的十六进制摘要

示例

def hash_with_MD5(message):
   encoded=message.encode()
   print ("Hashed with MD5:", hashlib.md5(encoded).hexdigest())
def hash_with_SHA(message):
   encoded=message.encode()
   print ("Hashed with SHA:", hashlib.sha256(encoded).hexdigest())
def hash_with_blake(message):
   encoded=message.encode()
   print ("Hashed with blake2b:",   hashlib.blake2b(encoded).hexdigest())
message='tutorialspoint'
hash_with_MD5(message)
hash_with_SHA(message)
hash_with_blake(message)

输出

Hashed with MD5: 6c60b3cfe5124f982eb629e00a98f01f
Hashed with SHA:
15e6e9ddbe43d9fe5745a1348bf1535b0456956d18473f5a3d14d6ab06737770
Hashed with blake2b:
109f6f017d7a77bcf57e4b48e9c744280ae7f836477c16464b27a3fe62e1353c70ec4c7f938080
60ee7c311094eede0235a43151c3d2b7401a3cb5a8f8ab3fbb 

步骤2:输入用户的密码字符串

下一步是从用户那里获取输入,用于存储密码。为了安全起见,在哈希密码之前,必须将用户输入的密码编码以确保它适合传递给哈希函数。这个编码操作由 encode() 函数执行。

语法

password=input("message").encode()

使用函数从用户那里接收密码,但是从用户那里接收到的密码不能用于哈希,因此使用encode()函数将其编码。这两个步骤在这里组合成一个单一的命令,方便编码和简单。

算法

步骤1 :使用函数从用户那里接收输入

步骤2 :将输入转换为编码格式

示例

password=input(“输入要哈希的密码:”).encode()

输出

输入要哈希的密码:Python 

步骤3:获取用户输入的哈希方法选择

我们将提供用户选择,以决定我们将使用哪种哈希算法安全地哈希密码。不同的方法有不同的优缺点,因此我们给用户选择的机会来决定哪个对于特定的密码最合适。此处我们使用一个简单的if-else结构来确定用户输入的选择。

语法

while True:
   choice = input("输入选择(1/2/3):")
      if choice in ('1', '2', '3'):
      try:
      ………………… 

在这里,我们询问用户执行的哈希类型以及选项列表。然后检查输入是否在有效输入列表中,如果是,则执行所要求的操作。否则,程序控制跳出循环。

算法

步骤1 − 请求用户输入

步骤2 − 检查用户输入是否有效

步骤3 − 执行所选操作

步骤4 − 询问是否要执行更多操作

示例

import hashlib
def hash_with_MD5(password):

   #encoded=password.encode()
   print ("使用MD5哈希:", hashlib.md5(password).hexdigest())
def hash_with_SHA(password):

   #encoded=password.encode()
   print ("使用SHA哈希:", hashlib.sha256(password).hexdigest())
def hash_with_blake(password):

   #encoded=password.encode()
   print ("使用blake2b哈希:", hashlib.blake2b(password).hexdigest())
print("选择哈希操作。") 
print("1.MD5")
print("2.SHA")
print("3.blake")
while True:

   # 从用户获取输入
   choice = input("输入选择(1/2/3):")

   # 检查选择是否在四个选项中
   if choice in ('1', '2', '3'):
      try:
         password=input('输入要哈希的密码:').encode()
      except ValueError:
         print("无效输入。请输一个字符串。")
         continue
      if choice == '1':
         hash_with_MD5(password)
      elif choice == '2':
         hash_with_SHA(password)
      elif choice == '3':
         hash_with_blake(password)

            # 检查用户是否想要进行另一个计算
      # 如果答案是否,则退出循环
      next_calculation = input("要进行下一个计算吗?(yes/no):")
      if next_calculation == "no":
         break
      else:
         print("无效输入。")

输出

选择哈希操作。
1.MD5
2.SHA
3.blake
输入选择(1/2/3):2
输入要哈希的密码:Python
使用SHA哈希:
18885f27b5af9012df19e496460f9294d5ab76128824c6f993787004f6d9a7db
要进行下一个计算吗?(yes/no):yes
输入选择(1/2/3):1
输入要哈希的密码:Tutorialspoint 
使用MD5哈希:da653faa9f00528be9a57f3474f0e437
要进行下一个计算吗?(yes/no):no 

结论

因此,我们已经构建了一个可以哈希用户密码并返回安全储存的程序。该程序运行成功,解决了重要的目的。可以进一步修改程序以实现新功能,我们稍后会做这些修改。

Python教程

Java教程

Web教程

数据库教程

图形图像教程

大数据教程

开发工具教程

计算机教程