Restricciones de Python y escritura de cifrado MD5

Hay dos formas de escribir restricciones en Python

  1. Se usa comúnmente para lanzar excepciones activamente a través de relaciones de herencia
  2. Mediante clase abstracta + método abstracto

1 Forma comúnmente utilizada de lanzar excepciones de forma activa a través de la herencia

No se lanzará ninguna excepción al informar errores en este método de envío.

class BaseMessage(object):
    def send(self):
    """
    必须继承BaseMessage,然后其中必须编写send方法。用于完成具体业务逻辑。
    """
    raise NotImplementedError(".send() 必须被重写.")   # 主动抛异常NotImplementedError,用exception也行但显得不专业
    # raise Exception(".send() 必须被重写.")

class Email(BaseMessage):               # 继承 BaseMessage  必须约束有send方法才行
    def send(self):
        pass                 # 发送邮件类
    def f1(self):
        pass
    def f2(self):
        pass

class Wechat(BaseMessage):           # 继承 BaseMessage  必须约束有send方法才行
    def send(self):
        pass               # 发送微信类
    def f1(self):
        pass

La clase BaseMessage se usa para restringir y restringir sus clases derivadas: asegúrese de que el método de envío debe escribirse en la clase derivada, de lo contrario, se puede informar un error cuando se ejecute.

2 A través de clase abstracta + método abstracto (no se usa comúnmente debido a la dificultad de escribir)

'''
遇到问题没人解答?小编创建了一个Python学习交流QQ群:778463939
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''
from abc import ABCMeta,abstractmethod

class Base(metaclass=ABCMeta): # 抽象类

    def f1(self):
        print(123)

    @abstractmethod                  # 抽象方法装饰器
    def f2(self): # 抽象方法
        pass

class Foo(Base):
    def f2(self):
        print(666)

obj = Foo()
obj.f1()

cifrado

El cifrado es irreversible, para evitar la colisión de la base de datos, debe haber una operación de salazón

import hashlib         # 导入hashlib 模块

SALT = b'2erer3asdfwerxdf34sdfsdfs90'               #  盐 盐必须是字节码

def md5(pwd):                # 传入密码
    # 实例化对象      加盐
    obj = hashlib.md5(SALT)                                      
    # 写入要加密的字节
    obj.update(pwd.encode('utf-8'))
    # 获取密文
    return obj.hexdigest() # 21232f297a57a5a743894a0e4a801fc3 # 66fbdc0f98f68d69cd458b0cee975fe3 

user = input("请输入用户名:")
pwd = input("请输入密码:")
if user == 'oldboy' and md5(pwd) == 'c5395258d82599e5f1bec3be1e4dea4a':
    print('登录成功')
else:
    print('登录失败')

Supongo que te gusta

Origin blog.csdn.net/qdPython/article/details/112672431
Recomendado
Clasificación