URLconf
- url()
-
url()
正则表达式中的参数既可以是位置参数,也可以是关键字参数
# 位置参数,/article/2020对应的view函数为year_archive(request, '2020') url(r'^article/([0-9]{4}/$', views.year_archive, name='year_archive') # 关键字参数,/article/2020对应的view函数为year_archive(request, year='2020') url(r'^article/(?P<year>[0-9]{4})/$', views.year_archive, name='year_archive') # 当然,`views.year_archive`函数定义时的API为`year_archive(request, year)`即可,因为其既可以接受位置参数,也可以接受关键字参数
- 模板中url标签
# 传入位置参数 {% url 'year_archive' 2020 %} # 传入关键字参数 {% url 'year_archive' year=2020 %}
- url()中其它参数
url(r'blog/(?P<year>[0-9]{4})/$, views.year_archive, {'foo': 'bar'}) # /blog/2020/将会调用year_archive(request, year='2020', foo='bar') # 注意:若url()函数中含有include(),那么字典中的参数将会应用到每个包含的url的views中
-
- reverse()
API:reverse(viewname, urlconf=None, args=None, kwargs=None, current_app=None) # args是位置参数,kwargs是关键字参数
Views
- Http404
可以自己实现引发Http404
异常,并定义异常页面:
在templates/
的直接目录下创建404.html
文件,当DEBUG
设置为False
时,该模板将会被Http404
异常使用 - 重载'错误'视图函数
必须在URLconf中进行重载:# 在mysite.views中定义重载视图函数 handler404 = 'mysite.views.my_custom_page_not_found_view' # 如不重载,则默认为是django.views.defaults.page_not_found # 需要返回HttpResponseNotFound handler500 = 'mysite.views.my_custom_error_view' # 如不重载,则默认为是django.views.defaults.server_error # 需要返回HttpResponseServerError handler403 = 'mysite.views.my_custom_permission_denied_view' # 如不重载,则默认为是django.views.defaults.permission_denied # 需要返回HttpResponseForbidden handler400 = 'mysite.views.my_custom_bad_request_view' # 如不重载,则默认为是django.views.defaults.bad_request # 需要返回HttpResponseBadRequest
快捷函数(django.shortcuts)
- render(request, template_name, context=None, content_type=None, status=None, user=None)
-
content_type
:默认为text/html(在DEFAULT_CONTENT_TYPE中设置) -
status
:默认为200 -
using
:加载模板使用的引擎名称
-
- redirect(to, permanent=False, *args, **kwargs)
返回HttpResponseRedirect
参数to
可以是- 一个
model
对象(自动调用该数据模型对象的get_absolute_url()
函数) - 一个视图函数名称(可以使用
reverse()
函数) - 一个绝对URL路劲
- 一个
- get_object_or_404(klass, *args, *kwargs)
-
klass
:Model类/Manager/QuerySet实例 -
**kwargs
:查询参数,将会被用于get()方法
等价于from django.shortcuts import get_object_or_404 def my_view(request): my_obj = get_object_or_404(MyModel, pk=1)
from django.http import Http404 def my_view(request): try: my_obj = MyModel.objects.get(pk=1) else: raise Http404("No MyModel matches the given query.")
-
- get_list_or_404(klass, *args, **kwargs)
通过filter()
进行查询
视图中的装饰器(django.views.decorators.http)
- 限制HTTP请求方法
限制视图函数可用的请求方法(若不符合要求,则返回django.http.HttpResponseNotAllowed
)- require_http_methods(reuqest_method_list)
设置允许多个请求方法from django.views.decorators.http import require_http_methods # 方法使用大写表示 @require_http_methods(["GET", "POST"]) def my_view(request): # I can assume now that only GET or POST requests make it this far # ... pass
- require_GET():只允许get方法
- require_POST():只允许post方法
- require_safe():允许get和head方法
- require_http_methods(reuqest_method_list)
request和response
Django通过request
和response
对象在系统中传递状态
当页面被创建,Django创建HttpRequest对象来保存元数据(视图函数中的第一个参数);每个视图函数则返回一个HttpResponse对象
HttpRequest和HttpResponse对象在django.http模块中定义