<玩转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
...
<玩转Django2.0>读书笔记:URL规则和视图的更多相关文章
- <玩转Django2.0>读书笔记:模板和模型
1. 模板内置标签 Django常用内置标签 标签 描述 {% for %} 遍历输出变量的内容 {% if %} 对变量进行条件判断 {% csrf_token %} 生成csrf_token标签, ...
- <玩转Django2.0>读书笔记:表单
1. 表单字段 参考: 官方文档 Django表单字段汇总 2. 表单代码示例(forms.Form) # form.py代码 # 获取数据库数据 choices_list = [(i+1,v['ty ...
- <玩转Django2.0>读书笔记:邮件和分页
1. 发送邮件 # settings.py设置 # 邮箱设置 EMAIL_USE_SSL = True # 邮件服务器 EMAIL_HOST = 'smtp.qq.com' # 邮件服务端口 EMAI ...
- 《玩转Django2.0》读书笔记-编写URL规则
<玩转Django2.0>读书笔记-编写URL规则 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. URL(Uniform Resource Locator,统一资源定位 ...
- 《玩转Django2.0》读书笔记-Django建站基础
<玩转Django2.0>读书笔记-Django建站基础 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.网站的定义及组成 网站(Website)是指在因特网上根据一 ...
- 《玩转Django2.0》读书笔记-探究视图
<玩转Django2.0>读书笔记-探究视图 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 视图(View)是Django的MTV架构模式的V部分,主要负责处理用户请求 ...
- 《玩转Django2.0》读书笔记-Django配置信息
<玩转Django2.0>读书笔记-Django配置信息 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 项目配置是根据实际开发需求从而对整个Web框架编写相应配置信息. ...
- Django2.0中得url路由path得用法
Django2.0中,url得匹配规则更新了,在django1.0中,url是用正则表达式书写得,相对来说比较繁琐一些,在django2.0中进行了升级优化,改为了path from django.u ...
- 玩转 Django2.0 笔记1
模板静态 路由 urls.py urlpatterns = [ path("<year>/<int:month>/<slug:day>",my ...
随机推荐
- 一次对JDK进行"减肥"的记录
起因 最近做的一个小项目,因为要涉及到批量部署,每次在部署之前都需要在各个主机上先安装jdk环境(为了使用jdk自带的工具如jps等,所以没有单纯安装jre),但是因为jdk文件太大(以jdk-8u1 ...
- JS“盒子模型”
列举几个常用的属性 client系列 clientWidth - 盒子真实内容的宽度[content+padding左右],不包括边线和滚动条 clientHeight - 盒子真实内容的高度[con ...
- js变量类型和计算
# js入门基础-变量类型和计算 ` --首先由于我使用了一个不太合格的markdown来编写来文章,所以在移动端阅读不要太方便,建议移动端使用横屏模式或pc端阅读,当然如果你有平板那是最好的. -- ...
- LeetCode第十九题-链表节点的删除
Remove Nth Node From End of List 问题简介;给定链表,从链表末尾删除第n个节点并返回其头部 例: 给定链表:1-> 2-> 3-> 4-> 5, ...
- git本机服务器配置(一):git的安装
1. 下载git的Windows版本 https://gitforwindows.org/ 2. 安装 点击next 不需要更改,直接点击next 配置git编辑器,我安装了notepad++所以就选 ...
- Q - N! HDU - 1042
使用java还不熟练,错误在于读入.应用in.hasNext() 代码 import java.text.ParseException; import java.text.SimpleDateForm ...
- 「luogu4462」[CQOI2018] 异或序列
「luogu4462」[CQOI2018]异或序列 一句话题意 输入 \(n\) 个数,给定\(k\),共 \(m\) 组询问,输出第 \(i\) 组询问 \(l_i\) \(r_i\) 中有多少个连 ...
- Laravel-google-authenticator--Google验证码
开发前的准备 安装Laravel 安装二维码生成器QrCode,没有安装也可以,接下来会安装 安装拓展 1.运行如下代码安装拓展包: composer require "earnp/lara ...
- C - BLG POJ - 1417 种类并查集加dp(背包)
思路:刚看这道题感觉什么都不清楚,人物之间的关系一点也看不出来,都不知道怎么写,连并查集都没看出来,但是你可以仔细分析一下,当输入字符串为“yes”的时候,我们设输入的值为x和y,当x为天使是则由题可 ...
- java 冒泡排序 day003
一.冒泡排序: 利用冒泡排序对数组进行排序 二.基本概念: 依次比较相邻的两个数,将小数放在前面,大数放在后面.即在第一趟:首先比较第1个和第2个数,将小数放前,大数放后.然后比较第2个数和第3个数, ...