浏览 3535 次
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2007-10-17
这段时间用django做一个小型的应用系统,虽然其自动生成的后台管理功能很实用,可是毕竟都是按照django自己的方式在表达,很多情况下,并不一定就满足用户的要求,于是我就脱其衣,剥其皮,对其自动生成后台的源码琢磨琢磨。这篇文章就来自于这次源码的阅读工作。
举个很简单,但是在web开发工作中最常见的场景,很多时候,你的很多url在真正执行操作前,都要验证用户的权限,总不成每回儿都写代码吧,因此你可能会把它写成一个共用的模块,要用的时候就调用,但是我今天却要用另外一种方式来解决问题,说白了,就是实现decorator模式,我们先来看简单的一段代码:
python 代码
这段代码运行的结果是: 输出结果
大家看看上面的代码,fun1和fun2可以理解为你要访问的url要执行的操作,而decorator就是你要做的权限检查,在这种方式下你的代码会很干净,不是吗? 如果有兴趣,可阅读django.contrib.admin.views下面的main.py decorators.py 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2007-10-17
Python 2.4还可以用更简单的Decorator语法:
@decorator def fun1(x,y): pass |
|
返回顶楼 | |