zoukankan      html  css  js  c++  java
  • 约束、自定义异常、加密、日志处理

    一、约束

      BaseMessage类用于约束,约束其派生类:保证派生类中必须编写方法,不然执行就可能报错。

    class BaseMessage(object):
        def send(self,x1):
            """
            必须继承BaseMessage,然后其中必须编写send方法。用于完成具体业务逻辑。
            """
            raise NotImplementedError(".send() 必须被重写.")
    
    class Email(BaseMessage):
        def send(self,x1):
            """
            必须继承BaseMessage,然后其中必须编写send方法。用于完成具体业务逻辑。
            """
            pass
    
    obj = Email()
    obj.send(1)

      1.什么是接口以及作用:

        接口是一种数据类型,主要用于约束派生类中必须实现的指定方法

        python中不存在接口,java、C#中存在

      2.python中使用什么来约束:

        抽象类+抽象方法(编写上麻烦,不推荐使用)

    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()

        人为主动抛出异常

      3.约束时,抛出的异常是否可以使用其他:

    不专业:raise Exception(".send() 必须被重写.")
    专业:raise NotImplementedError(".send() 必须被重写.")

    二、自定义异常

    class MyException(Exception):    #必须继承Exception
        def __init__(self, code, msg):
            self.code = code
            self.msg = msg
    
    try:
        # 知识点:主动抛出异常 
        raise MyException(1000, '操作异常')
    
    except KeyError as obj:
        print(obj, 1111)
    except MyException as obj:  # 知识点:捕获异常 
        print(obj, 2222)
    except Exception as obj:
        print(obj, 3333)

    三、加密(hashlib模块)

      关键字:撞库、加盐

    import hashlib
    
    SALT = b'2erer3asdfwerxdf34sdfsdfs90'
    
    def md5(pwd):
        # 实例化对象
        obj = hashlib.md5(SALT)
        # 写入要加密的字节
        obj.update(pwd.encode('utf-8'))
        # 获取密文
        return obj.hexdigest() # 21232f297a57a5a743894a0e4a801fc3 # 66fbdc0f98f68d69cd458b0cee975fe3 # c5395258d82599e5f1bec3be1e4dea4a
    
    
    user = input("请输入用户名:")
    pwd = input("请输入密码:")
    if user == 'oldboy' and md5(pwd) == 'c5395258d82599e5f1bec3be1e4dea4a':
        print('登录成功')
    else:
        print('登录失败')
    View Code

    四、日志

      日志主要是给开发人员看的,用于排查错误

    import logging
    logger = logging.basicConfig(filename="zhangqing",
                                 format="%(asctime)s - %(name)s - %(levelname)s -%(module)s:  %(message)s",
                                 datefmt="%Y-%m-%d %H:%M:%S",
                                 level=30)
    
    logging.debug('x1') # 10
    logging.info('x2')  # 20
    logging.warning('x3') # 30
    logging.error('x4')    # 40
    logging.critical('x5') # 50
    logging.log(10,'x6')
    
    import traceback
    
    def func():
        try:
            a = a +1
        except Exception as e:
            # 获取当前错误的堆栈信息
            msg = traceback.format_exc()
            logging.error(msg)
    func()
    View Code

      自定义日志

    import logging
    
    
    # 创建一个操作日志的对象logger(依赖FileHandler)
    file_handler = logging.FileHandler('l1.log', 'a', encoding='utf-8')
    file_handler.setFormatter(logging.Formatter(fmt="%(asctime)s - %(name)s - %(levelname)s -%(module)s:  %(message)s"))
    
    logger1 = logging.Logger('s1', level=logging.ERROR)
    logger1.addHandler(file_handler)
    
    
    logger1.error('123123123')
    
    
    
    # 在创建一个操作日志的对象logger(依赖FileHandler)
    file_handler2 = logging.FileHandler('l2.log', 'a', encoding='utf-8')
    file_handler2.setFormatter(logging.Formatter(fmt="%(asctime)s - %(name)s - %(levelname)s -%(module)s:  %(message)s"))
    
    logger2 = logging.Logger('s2', level=logging.ERROR)
    logger2.addHandler(file_handler2)
    
    logger2.error('666')
    View Code
  • 相关阅读:
    LeetCode 第46题 全排列
    docker安装单节点minio
    git的免密设置
    mysql不同字符集的转换过程
    二进制安装MySQL 8.0
    二进制方式安装mysql5.7.24
    mysql替换字段中指定的部分字符串
    Minio设置永久下载链接
    pt-online-schema-change使用详解
    Oracle pctfree和pctused详解
  • 原文地址:https://www.cnblogs.com/qq849784670/p/9567526.html
Copyright © 2011-2022 走看看