本文实例讲述了Python实现带参数的用户验证功能装饰器。分享给大家供大家参考,具体如下:
user_list = [ {'name': 'sb1', 'passwd': '123'}, {'name': 'sb2', 'passwd': '123'}, {'name': 'sb3', 'passwd': '123'}, {'name': 'sb4', 'passwd': '123'} ] # 初始状态,用来保存登陆的用户, client_dic = {'username': None, 'login': False} # 添加新功能 def auth(auth_type='filedb'): def auth_func(func): def wrapper(*args, **kwargs): print(auth_type) if auth_type == 'fildb': # 参数检查,判断是否有用户登录,如果有,不用验证,直接执行函数的功能 if client_dic['username'] and client_dic['login']: res = func(*args, **kwargs) return res # 输入用户名和密码 username = input('用户名:').strip() passwd = input('passwd:').strip() # 对比列表,检查用户名和密码是否正确 for user_dic in user_list: if username == user_dic['name'] and passwd == user_dic['passwd']: client_dic['username'] = user_dic['name'] client_dic['login'] = True res = func(*args, **kwargs) return res else: print('用户名或者密码错误!') elif auth_type == 'pass': print('不知道什么验证方式') res = func(*args, **kwargs) return res else: print('一脸蒙蔽的验证方式') res = func(*args, **kwargs) return res return wrapper return auth_func @auth(auth_type='filedb') def index(): print("欢迎来到主页") @auth(auth_type='user') def home(name): print("欢迎回家:%s" % name) @auth(auth_type='pass') def shoppping_car(): print('购物车里有[%s,%s,%s]' % ('奶茶', '妹妹', '娃娃')) print(client_dic) index() print(client_dic) home('root')
运行结果:
{'username': None, 'login': False}
filedb
一脸蒙蔽的验证方式
欢迎来到主页
{'username': None, 'login': False}
user
一脸蒙蔽的验证方式
欢迎回家:root
更多关于Python相关内容可查看本站专题:《Python数据结构与算法教程》、《Python Socket编程技巧总结》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》及《Python入门与进阶经典教程》
希望本文所述对大家Python程序设计有所帮助。
本文向大家介绍Python使用装饰器模拟用户登陆验证功能示例,包括了Python使用装饰器模拟用户登陆验证功能示例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Python使用装饰器模拟用户登陆验证功能。分享给大家供大家参考,具体如下: 运行结果: 更多关于Python相关内容感兴趣的读者可查看本站专题:《Python数据结构与算法教程》、《Python编码操作技巧总结》、《Python
问题内容: 我在装饰器传递变量时遇到问题。我可以通过以下装饰器语句来做到这一点: 但不幸的是,该声明不起作用。也许也许有更好的方法来解决此问题。 问题答案: 带参数的装饰器的语法有些不同-带参数的装饰器应返回一个函数,该函数将接受一个函数并返回另一个函数。因此,它实际上应该返回一个普通的装饰器。有点混乱吧?我的意思是: 在这里,你可以阅读有关该主题的更多信息-也可以使用可调用对象来实现此目的,这也
问题 你想写一个装饰器,既可以不传参数给它,比如 @decorator , 也可以传递可选参数给它,比如 @decorator(x,y,z) 。 解决方案 下面是9.5小节中日志装饰器的一个修改版本: from functools import wraps, partial import logging def logged(func=None, *, level=logging.DEBUG,
本文向大家介绍python django 实现验证码的功能实例代码,包括了python django 实现验证码的功能实例代码的使用技巧和注意事项,需要的朋友参考一下 我也是刚学Python Django不久很多都不懂,所以我现在想一边学习一边记录下来然后大家一起讨论! 验证码功能一开始我在网上找了很多的demo但是我在模仿他们写的时候,发现在我的版本上根本就不能运行起来在前端页面显示的时候是图
我想用最新的弹性4J断路器装饰我的服务呼叫,我当前的代码看起来像: 以前有一个名为的方法,我很想使用它,但是由于未知的原因,它在resilience4j的最新版本中被删除了(我使用的是最新的1.4版本) 有人知道为什么这个函数被删除了吗?我看到有像这样的方法,但是我需要向我的服务传递一个参数(对于supplier是不允许的)
问题内容: 装饰器模式(功能)有很多好处: 当一个方法具有许多正交的关注点时,这将非常有用…也就是说,这些关注点均不相关,除了我们每次调用我们的方法时都希望全部(或部分)关注它们。这是装饰器模式真正有用的地方。 通过实现装饰器模式,我们订阅了开闭主体。我们的方法对将来的扩展开放,但对将来的修改不开放。遵循开放-封闭原则有很多有趣的好处。 但是,我发现的所有示例都非常复杂(例如,编写带有许多中间件的