视图的功能
接收请求 进行处理 与M和T进行交互 返回应答
返回HttpResponse
类型的html内容 或重定向 redirect
视图的使用过程
1.定义视图函数
request
参数必须有
request
是一个HttpRquest
类型的对象
形参名可以变化 但一般不修改
2.配置URLs
建立url和视图函数之间的对应关系
url匹配的过程
层级进入URLS.py
文件进行匹配 被将匹配的部分不再进入下级URLS文件
匹配 ?
后的不匹配
正则的开始不能使用 \
如\index
错误视图
关闭DEBUG
在项目配置目录下setting.py
设置DEBUG = False
关闭DEBUG功能
设置ALLOWED_HOST = ["*"]
允许所有IP访问
404错误
找不到页面会返回404错误
默认404会显示NOT Found页面
在templates下新建404.html
将使用此模板替代默认404页面
500错误
视图错误会返回500错误
默认500会显示server error
在templates下新建500.html
将使用此模板替代默认500页面
捕获url参数
进行url匹配时 把需要捕获的部分设置成正则表达式的组
Django框架 会自动把组内参数传递给对应视图函数
1.位置参数
使用正则位置参数 视图的形参名可以随意指定
re_path(r"index(\d+)", views.index)
(\d+)内的参数将被传递给index视图函数的形参
2.关键字参数
re_path(r"index(?P
(?P
视图函数必须以name命名形参
视图的参数
def index(request, name)
return render(request, index.html, {})
request 包含 用户通过浏览器请求的参数
name 包含 模板文件中设置的参数
request参数
request参数是一个WSGIRequest对象
WSGIRequest 对象属于django.core.handlers.wsgi.WSGIRequest
request对象包含浏览器请求的信息 是将WISG协议中传递给框架的env信息的再次封装
WSGIRequest对象的属性
以下属性都是只读的,除非特别说明
request.path: 返回字符串 表示请求的路径 不包含域名和参数部分
request.method: 返回字符串 表示HTTP请求的方式 如: "GET" "POST"
request.encoding: 返回字符串 表示请求的编码格式 如果为None表示使用浏览器默认设置utf-8 注意:这个属性不是只读的如果修改 接下来对属性的访问使用新的encoding值
request.GET: 返回QueryDict对象 包含get请求的所有参数
request.POST: 返回QuertDict对象 包含post请求的所有参数
request.FILES: 返回MultiValueDict对象 类似于字典 包含所有上传文件
request.COOKIES: 返回标准Python字典 包含所有的cookies 键值都为字符串
request.session: 返回SessionStore对象 类似于字典 表示当前的会话 只有Django启用会话功能才可用 详见"状态保持" 注意:这个属性不是只读的
GET 提交的form表单 参数在 url中的?后面 多个参数以&连接
POST 提交的form表单 参数在 http请求头中的Form Data中
POST 提交参数应用于敏感信息的提交 因为不会直接显示在连接中
QueryDict对象
WSGIRequest 对象的GET 和POST 属性用来取值
request.GET 或 request.POST 是一个 QueryDict 对象
QueryDict 对象属于 django.http.request.QueryDict
创建QueryDict对象
q = QueryDict("a=1&a=2&b=3")
对QueryDict对象取值
q["a"] 返回一个字符串
q.get("b") 返回一个字符串
q.getlist("a") 返回一个列表
如果取值不存在的键 使用[]取值会报错KeyError 使用get() 返回None 使用getlist 返回空列表
get()方法设置默认值
q.get("d", "default") 如果没有d这个Key 会返回字符串default
q.getlist("d", [1, "2"]) 如果没有d 这个Key 会返回列表[1, "2"]
QueryDict与普通字典的区别
QueryDict的Key可以对应多个值
q = queryDict("a=1&a=2&a=3")
用[]和get()取值有多个值的QueryDict对象时 只返回最后一个Key的值
q["a"] 返回 3
q.get("a") 返回 3
如果要对QueryDict取值Key对应的所有值 使用getlist()方法
q.getlist("a") 返回一个列表["1", "2", "3"]
Cookie
Cookie 在访问网站时服务器生成的储存在浏览器的一段文本信息
Django中cookie中的值只以字符串形式储存
访问服务器时服务器设置一个cookie key为要保存的id值为要保存的信息
将cookie发送给浏览器浏览器保存在本地
访问服务器时浏览器发送cookie 服务器通过cookie的id取出信息用来判断状态
Cookie的特点
request.COOKIES是一个普通的Python字典
1.以键值对的方式存储 并且只储存字符串类型的值
2.通过浏览器访问网站时 浏览器会将所有跟这个网站相关的Cookie发送给网站
3.基于域名安全(不会将其他网站的cookie发给不相关的网站)
4.有过期时间 如果不指定时间 默认关闭浏览器后cookie就会过期
设置cookie
通过HttpResponse类的对象或者它的子类的对象
使用对象.set_cookie()设置cookie
对象.set_cookie("key", value, max_age)
response = HttpResponse("设置cookie")
response.set_cookie("num", 1)
renturn response
实际是服务器在ResponseHeader里设置了Set-Cookie的值
浏览器发现Set-Cookie的值后会在本地存储对应的cookie
读取cookie
通过HttpRequest类的对象或者它的子类的对象
使用对象.COOKIES[]读取cookie
对象.COOKIES["key"]
cookie = request.Cookie["num"]
return HttpResponse(cookie)
在读取cookie时 实际是浏览器在RequsetHeader里设置了Cookie的值
浏览器将本地保存的有关这个网站的cookie保存在Cookie全部发送给服务器
Cookie的寿命
浏览器在保存cookie时默认当浏览器关闭时使cookie过期
response.set_cookie(max_age= , expirse= )
max_age= 以秒为单位设置cookie过期时间
expirse= 以到期日期计算cookie过期时间
session
Django的session中可以储存任意类型的数据
所有的session信息储存在服务器数据库中的session表中
表的主键叫做session_key唯一标示session在表中的位置
表的值叫做 session_data储存了设置的session键值对
过期时间叫做expire_date储存了session过期日期
访问服务器时服务器设置session为数据表创建记录
服务器发送一个key为sessionid值为session_key的cookie给浏览器
访问时服务器通过key为sessionid的cookie获得session_key
后台再通过session_key在数据库中获得session_data
session特点
1.以键值对的方式存储 并且可以储存任意类型的值
2.依赖于cookie 唯一标识码sessionid就是cookie的key session_key就是cookie的值
3.有过期时间 如果不指定 默认两周时间
设置session
通过HttpRequest对象的session属性设置和读取session信息
保存时类似于给字典添加键值对
对象.session["key"] = value
request.session["username"] = "smart"
读取session
通过HttpRequset对象的session属性读取session信息
取值和没有值时的默认值
username = 对象.session["username"]
username = 对象.session.get("key", 默认值)
username = request.session["username"]
username = request.session.get("username", "没有数据")
session的方法
session_data在数据表中的状态
4b662403cdb5656fdba155811da63a59046fe33a:{"username":"smart","password":"passwd"}
删除session值的部分 也就是session_data中括号中的部分
对象.session.clear()
删除session整条数据 也就是session_data对应的整条数据表记录
对象.session.flush()
删除session中指定的键值对
del 对象.session["key"]
判断session中是否有对应的key
对象.session.has_key("key")
设置会话的超时时间
如果不设置值则等同于设置为None
对象.session.set_expory(value)
- 如果value是一个整数,sessionid的cookie将在value秒后过 session也会在value秒后过期
- 如果value为0,sessionid的cookie浏览器关闭时过期 session会在两周后过期
- 如果value为None,sessionid的cookie两周后过期 session也会在两周后过期
cookie和session的应用场景
cookie: 记住用户名 安全性要求不高
session: 银行卡账户 密码 涉及到安全性比较高的数据