<玩转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

也可以使用StreamingHttpResponseFileResponse实现下载,推荐使用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
...
posted @ 2019-03-16 14:53  汪小鹏boy  阅读(266)  评论(0编辑  收藏  举报