Django URL 解析

1号门:http://www.yihaomen.com/article/python/355.htm


URLcanf常用正则:   
. (dot)任意单一字符\d任意一位数字[A-Z]A 到 Z中任意一个字符(大写)[a-z]a 到 z中任意一个字符(小写)[A-Za-z]a 到 z中任意一个字符(不区分大小写)+匹配一个或更多 (例如, \d+ 匹配一个或 多个数字字符)[^/]+一个或多个不为‘/’的字符*零个或一个之前的表达式(例如:\d? 匹配零个或一个数字)*匹配0个或更多 (例如, \d* 匹配0个 或更多数字字符){1,3}介于一个和三个(包含)之前的表达式(例如,\d{1,3}匹配一个或两个或三个数字)

http://hi.baidu.com/drunkdream/item/eb0f69361f4050d46c15e9df:

提供视图配置选项

def my_view(request, template_name): #比较常见的可供配置代码是模板名字
   var = do_something()
   return render_to_response(template_name, {'var': var})

 

使用缺省视图参数

def page(request, num='1'):#num有默认值
# ...

特殊情况下的视图
urlpatterns = patterns('',
('^auth/user/add/$', views.user_add_stage),#优先捕捉,短路逻辑
('^([^/]+)/([^/]+)/add/$', views.add_stage),
)

注意参数类型
urlpatterns = patterns('',
(r'^articles/(\d{4})/(\d{2})/(\d{2})/$', views.day_archive),
)
def day_archive(request, year, month, day):
date = datetime.date(int(year), int(month), int(day))

决定URLconf搜索的东西 ?

当一个请求进来时,Django试着将请求的URL作为一个普通Python字符串进行URLconf模式匹配(而不是作为一个Unicode字符串)。 它不包括 GET 或 POST 参数或域名。 它也不包括第一个斜杠,因为每个URL必定有一个斜杠。

例如,在向 http://www.example.com/myapp/ 的请求中,Django将试着去匹配 myapp/ 。在向 http://www.example.com/myapp/?page=3 的请求中,Django同样会去匹配 myapp/ 。

在解析URLconf时,请求方法(例如, POST , GET , HEAD )并 不会 被考虑。换而言之,对于相同的URL的所有请求方法将被导向到相同的函数中。 因此根据请求方法来处理分支是视图函数的责任。

视图函数的高级概念

def method_splitter(request, *args, **kwargs):#一*所有参数保存为元组,两*保存为字典
get_view = kwargs.pop('GET', None)
post_view = kwargs.pop('POST', None)
if request.method == 'GET' and get_view is not None:
return get_view(request, *args, **kwargs)
elif request.method == 'POST' and post_view is not None:
return post_view(request, *args, **kwargs)
raise Http404

包装视图函数
def requires_login(view):
def new_view(request, *args, **kwargs):
if not request.user.is_authenticated():
return HttpResponseRedirect('/accounts/login/')
return view(request, *args, **kwargs)
return new_view
函数requires_login,传入一个视图函数view,然后返回一个新的视图函数new_view.
这个新的视图函数new_view在函数requires_login内定义 
处理request.user.is_authenticated()这个验证,从而决定是否执行原来的view函数
在URLconf用requires_login来包装
(r'^view1/$', requires_login(my_view1)),
(r'^view2/$', requires_login(my_view2)),

包含其他URLconf
from django.conf.urls.defaults import *
urlpatterns = patterns('',
(r'^weblog/', include('mysite.blog.urls')),   #weblog/2007/
(r'^photos/', include('mysite.photos.urls')),
(r'^about/$', 'mysite.views.about'),
)
#mysite.blog.urls
from django.conf.urls.defaults import *
urlpatterns = patterns('',
(r'^(\d\d\d\d)/$', 'mysite.blog.views.year_detail'),#2007/
(r'^(\d\d\d\d)/(\d\d)/$', 'mysite.blog.views.month_detail'),
)


你可能感兴趣的:(Django)