<玩转Django2.0>读书笔记:URL规则和视图
1. 带变量的URL
#urls.py
from django.urls import path
from .view import *
urlpatterns = [
path('',index_views),
#添加带有整数的字符类型、整形和slug的URL
path('<year>/<int:month>/<slug>',mydate_views),
]
URL变量类型:
- 字符类型 : 默认类型,匹配任何非空字符串,但不含'/'
- int : 整型
- slug : 可理解为注释、后缀或附属等概念
- uuid : 匹配一个uuid格式对象.为防止冲突,规定必须使用破折号并且所有字母小写
from django.urls import re_path
from .views import *
urlpatterns = [
path('',index_views),
re_path('test/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})/(?P<day>[0-9]{2})',mydate_views),
]
使用正则表达式写法:
- ?P 是固定格式
为变量的编写规则 - [0-9]{4} 是正则表达式
2. 响应类型
视图函数return的响应类型
响应类型 | 说明 |
---|---|
HttpResponse('Hello World') | HTTP状态码200,请求已成功被服务器接收 |
HttpResponseRedirect('/admin/') | HTTP状态码302,重定向Admin站点的URL |
HttpResponsePermanentRedirect('/admin/') | HTTP状态码301,永久重定向Admin站点的URL |
HttpResponseBadRequest('BadRequest') | HTTP状态码400,访问的页面不存在或者请求错误 |
HttpResponseNotFound('NotFound') | HTTP状态码404,网页不存在或网页的URL失效 |
HttpResponseForbidden('NotFound') | HTTP状态码403,没有访问权限 |
HttpResponseNotAllowed('NotAllowed') | HTTP状态码405,不允许使用该请求方式 |
HttpResponseServerError('ServerError') | HTTP状态码500,服务器内容错误 |
响应类型代表HTTP状态码,其核心作用是Web Server服务器用来告诉客户端当前网页请求发生了事,或者当前Web服务器的响应状态
3. 文件下载
def download_views(request):
# 定义HttpResponse的响应类型为文件(text/csv),生成resp对象
resp = HttpResponse(content_type="text/csv")
# attachment设置文件下载方式,filename为文件名
resp['Content-Disposition'] = 'attachment;filename="somefilename.csv"'
# 使用csv模块加载resp对象,把数据写入resp对象所设置的csv文件
writer = csv.writer(resp)
writer.writerow(['First row','A','B','C'])
return resp
也可以使用StreamingHttpResponse
和FileResponse
实现下载,推荐使用FileResponse
def download_views2(request):
file = open('/home/tarena/简言.jpg','rb')
resp = FileResponse(file)
resp['Content-Type']='image/jpeg'
resp['Content-Disposition'] = 'attachment;filename="简言.jpg"'
return resp
关于文件下载类型,参考地址:
http://tool.oschina.net/commons
4. render(),redirect()函数
Django在django.http模块上进行封装.从而有了render(),redirect()函数
render()函数参数:
- request : 浏览器向服务器发送的请求对象,必须参数
- template_name : HTML模板文件名,用于生成HTML网页,必须参数
- context : 对HTML模板变量赋值,以字典格式表示,默认为空字典
- status : HTTP状态码,默认为200
- using : 设置HTML模板转换成HTML网页的模板引擎
5. request常用属性
属性 | 说明 | 实例 |
---|---|---|
COOKIES | 获取客户端Cookie信息 | data = request.COOKIES |
FILES | 字典对象,包含所有的上传文件.该字典有三个键:filename为上传文件名;content-type为上传文件的类型;content为上传文件内容 | file = request.FILES |
GET | 获取GET请求的请求参数,以字典形式存储 | request.GET.get('name') |
META | 获取客户端的请求头信息,以字典形式存储 | request.META.get('REMOTE_ADDR') #获取客户端的IP地址 |
method | 获取该请求的请求方式(GET或POST) | data = request.method |
path | 获取当前请求的URL地址 | path = request.path |
user | 获取当前请求的用户信息 | name = request.user.username |
6. 通用视图
Django植入了通用视图这一功能,该功能封装了视图开发常用的代码和模式
通用视图通过定义和声明类的形式实现的,根据用途划分为三大类:
- TemplateView 直接返回HTML模板,但无法将数据库的数据展示出来
- ListView 将数据库的数据传递给HTML,通常获取某个表的所有数据
- DetailView 将数据库的数据传递给HTML模板,通常获取数据表的单条数据
# urls.py
...
path('index/',ProductList.as_view())
...
# views.py
from django.views.generic import ListView
# 通用视图
class ProductList(ListView):
# 设置HTML模板的变量名称
context_object_name = "type_list"
# 设定HTML模板
template_name = "index.html"
# 查询数据
queryset = Product.objects.values('ttype').distinct()
# 重写 get_queryset 方法,对模型 Product 进行数据筛选
# def get_queryset(self):
# type_list = Product.objects.values('ttype').distinct()
# return type_list
# 添加其他变量
def get_context_data(self,**kwargs):
context = super().get_context_data(**kwargs)
context['name_list'] = Product.objects.values('name','ttype')
return context
通用视图还可以获取URL的参数和请求信息
# urls.py
...
path('index/<id>',ProductList.as_view(),{"name":"小米9"})
...
...
def get_queryset(self):
# 获取URL的变量id
print(self.kwargs['id'])
# 获取URL参数name
print(self.kwargs['name'])
# 获取请求方式
print(self.request.method)
type_list = Product.objects.values('ttype').distinct()
return type_list
...