这段时间用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就是你要做的权限检查,在这种方式下你的代码会很干净,不是吗?
如果有兴趣,可阅读django.contrib.admin.views下面的main.py decorators.py