收藏 分销(赏)

利用Python的装饰器解决Bottle框架中用户验证问题.doc

上传人:丰**** 文档编号:9758378 上传时间:2025-04-06 格式:DOC 页数:3 大小:21.50KB 下载积分:5 金币
下载 相关 举报
利用Python的装饰器解决Bottle框架中用户验证问题.doc_第1页
第1页 / 共3页
利用Python的装饰器解决Bottle框架中用户验证问题.doc_第2页
第2页 / 共3页


点击查看更多>>
资源描述
  这篇文章主要介绍了Python的Bottle框架中解决用户验证问题,代码基于Python2.x版本,需要的朋友可以参考下   首先来分析下需求,web程序后台需要认证,后台页面包含多个页面,最普通的方法就是为每个url添加认证,但是这样就需要每个每个绑定url的后台函数都需要添加类似或者相同的代码,但是这样做代码就过度冗余,而且不利于扩展.   接下来我们先不谈及装饰器,我们都知道Python是个很强大的语言,她可以将函数当做参数传递给函数,最简单的:   def p():   print 'Hello,world'   def funcfactor(func):   print 'calling function named', func.__name__   func()   print 'end'   funcfactor(p)   # 输出为:   # calling function named p   # Hello,world   # end   一目了然的程序,定义一个函数p(),将函数p当做参数传递给喊出funcfactor,在执行p函数前后加上一些动作.   我们还可以这么做:   def p():   print 'Hello,world'   def funcfactor(func):   print 'calling function named', func.__name__   return func   func = funcfactor(p)   func()   # 输出为:   # calling function named p   Hello,world   正如你看到的,我们可以将函数返回然后赋予一个变量,留待稍后调用.但是这种情况下我们要想在函数执行后做点什么就不可能,但是我们的Python是强大的,Python可以在函数中再嵌套一个函数,我们可以像下面这么做:   def p():   print 'Hello, world'   def funcfactor(func):   def wrapper():   print 'do something at start'   func()   print 'do something at end'   return wrapper   func = funcfactor(p)   func()   #输出为:   # do something at start   # Hello, world   # do something at end   下面我们来看看装饰器,上面的代码虽然实现的一个很困难的任务,但是还不够优雅,而且代码不符合Python的哲学思想,所以装饰器就应声而出,装饰器没有和上面的原理相同,同样用于包装函数,只是代码实现上更加优雅和便于阅读.装饰器以@开头后面跟上装饰器的名称,紧接着下一行就是要包装的函数体,上面的例子用装饰器可用如下方式实现:   def decorator(func):   def wrapper():   print 'do something at start'   func()   print 'do something at end'   return wrapper   @decorator   def p():   print 'Hello, world'   p()   #输出为:   # do something at start   # Hello, world   # do something at end   实际上装饰器并没有性能方面或其他方面的提升,仅仅是一种语法糖,就是上面一个例子的改写,这样更加优雅和便与阅读. 如果我们的p()函数不想仅仅只输Hello,world,我们想向某些我们指定的人打招呼:   def decorator(func):   def wrapper(*args, **kargs):   print 'do something at start'   func(**kargs)   print 'do something at end'   return wrapper   @decorator   def p(name):   print 'Hello', name   p(name="Jim")   #输出为:   # do something at start   # Hello Jim   # do something at end   装饰器在装饰不需要参数的装饰器嵌套函数不是必须得,如果被装饰的函数需要参数,必须嵌套一个函数来处理参数. 写到这里想必大家也知道装饰器的用法和作用.现在回到正题,如何优雅的给后台url加上验证功能?毫无疑问我们使用装饰器来处理:   def blog_auth(func):   '''   定义一个装饰器用于装饰需要验证的页面   装饰器必须放在route装饰器下面   '''   # 定义包装函数   def wrapper(*args, **kargs):   try:   # 读取cookie   user = request.COOKIES['user']   shell = request.COOKIES['shell']   except:   # 出现异常则重定向到登录页面   redirect('/login')   # 验证用户数据   if checkShell(user, shell):   # 校验成功则返回函数   return func(**kargs)   else:   # 否则则重定向到登录页面   redirect('/login')   return wrapper   可以再需要验证的地方添加blog_auth装饰器:   @route('/admin:#/?#')   @blog_auth   def admin():   '''   用于显示后台管理首页   '''   TEMPLATE['title'] = '仪表盘 | ' + TEMPLATE['BLOG_NAME']   TEMPLATE['user'] = request.COOKIES['user']   articles = []   for article in db.posts.find().sort("date",DESCENDING).limit(10):   articles.append(article)   # 将文章列表交给前台模版   TEMPLATE['articles'] = articles   return template('admin.html',TEMPLATE)   至此bottle验证的问题就很优雅的用装饰器解决了.   更多信息请查看IT技术专栏   
展开阅读全文

开通  VIP会员、SVIP会员  优惠大
下载10份以上建议开通VIP会员
下载20份以上建议开通SVIP会员


开通VIP      成为共赢上传

当前位置:首页 > 包罗万象 > 大杂烩

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        抽奖活动

©2010-2025 宁波自信网络信息技术有限公司  版权所有

客服电话:4009-655-100  投诉/维权电话:18658249818

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :微信公众号    抖音    微博    LOFTER 

客服