python中如何简单的实现decorator模式--由django admin源码所得体会
这段时间用django做一个小型的应用系统,虽然其自动生成的后台管理功能很实用,可是毕竟都是按照django自己的方式在表达,很多情况下,并不一定就满足用户的要求,于是我就脱其衣,剥其皮,对其自动生成后台的源码琢磨琢磨。这篇文章就来自于这次源码的阅读工作。举个很简单,但是在web开发工作中最常见的场景,很多时候,你的很多url在真正执行操作前,都要验证用户的权限,总不成每回儿都写代码吧,因此你可能会把它写成一个共用的模块,要用的时候就调用,但是我今天却要用另外一种方式来解决问题,说白了,就是实现decorator模式,我们先来看简单的一段代码:
python 代码
[*]# decorator.py
[*]# 修饰函数
[*]def decorator(fun):
[*] def ifun(*args, **kwargs):
[*] args = (i+1 for i in args)
[*] return fun(*args, **kwargs)
[*] return ifun
[*]
[*]# 被修饰函数1
[*]def fun1(x,y):
[*] return x+y
[*]fun1 = decorator(fun1)
[*]
[*]# 被修饰函数2
[*]def fun2(x,y,z):
[*] return x+y+z
[*]fun2 = decorator(fun2)
[*]
[*]# 测试代码
[*]a = 3
[*]b = 4
[*]c = 5
[*]print fun1(a,b)
[*]print fun2(a,b,c)
这段代码运行的结果是:
输出结果
[*]9
[*]15
大家看看上面的代码,fun1和fun2可以理解为你要访问的url要执行的操作,而decorator就是你要做的权限检查,在这种方式下你的代码会很干净,不是吗?http://bluecrystal.iteye.com/javascripts/fckeditor/editor/images/smiley/msn/wink_smile.gif
如果有兴趣,可阅读django.contrib.admin.views下面的main.py decorators.py
页:
[1]