写一下Cookie、重定向、Session

Cookie

测试代码,承接前面的代码:

路由: booktest/urls.py

urlpatterns = [
url('^$',views.index), # 路由到views.py中的index()函数
url('^index', views.index, name="index"),
url('^(\d+)$', views.integer),
url('^(?P<p2>\d+)/(?P<p3>\d+)/(?P<p1>\d+)$', views.date),
url('^req$', views.req),
url('^resp$', views.resp),
url('^cookie$', views.cookie),
]

booktest/views.py

def cookie(request):
resp = HttpResponse('cookie')
resp.set_cookie('name', 'zhangsan')
return resp

访问 http://127.0.0.1:8080/booktest/cookie  - “查看元素/检查”- “网络”- 左边选择浏览的网页 - 右边查看响应头

此时cookies就保存到浏览器上

然后可以把服务器上的代码set_cookie去掉

def cookie(request):
resp = HttpResponse('cookie')
#resp.set_cookie('name', 'zhangsan')
return resp

访问同一个网页 http://127.0.0.1:8080/booktest/cookie  检查

由于之前的cookies已经保存到浏览器上了,所以现在就把浏览器上的cookie发送到服务端。

接下来需要服务器去接收cookie

路由 booktest/urls.py

urlpatterns = [
url('^$',views.index), # 路由到views.py中的index()函数
url('^index', views.index, name="index"),
url('^(\d+)$', views.integer),
url('^(?P<p2>\d+)/(?P<p3>\d+)/(?P<p1>\d+)$', views.date),
url('^req$', views.req),
url('^resp$', views.resp),
url('^cookie$', views.cookie),
url('^cookie2$', views.cookie2),
]

视图 booktest/views.py

def cookie2(request):
resp = HttpResponse()
cookie = request.COOKIES
if 'name' in cookie:
resp.write(cookie['name'])
return resp

访问http://127.0.0.1:8080/booktest/cookie2  就会把cookie发送到服务器,然后服务器端获取name的值,并显示出来

重定向

重定向是指服务器端跳转。

直接把请求指向另外一个地方

路由 booktest/urls.py

urlpatterns = [
url('^$',views.index), # 路由到views.py中的index()函数
url('^index', views.index, name="index"),
url('^(\d+)$', views.integer),
url('^(?P<p2>\d+)/(?P<p3>\d+)/(?P<p1>\d+)$', views.date),
url('^req$', views.req),
url('^resp$', views.resp),
url('^cookie$', views.cookie),
url('^cookie2$', views.cookie2),
url('^redirect$', views.redirect),
url('^redirect2$'
, views.redirect2),
]

视图 booktest/views.py

from django.shortcuts import render
from django.http import HttpResponse, HttpResponseRedirect
from django.template import loader, RequestContext
def redirect(request):
return HttpResponseRedirect('/booktest/redirect2') def redirect2(request):
return HttpResponse('这里重定向后的页面')

Session

首先需要打开数据库的功能。

django3/settings.py

DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'django3',
'USER': 'root',
'PASSWORD': '',
'HOST': 'localhost',
'PORT': ''
}
}

确保INSTALL_APP中已经打开了session的功能

INSTALLED_APPS = (
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'booktest'
)

确保MIDDLEWARE_CLASSES中也添加了SESSION的功能

MIDDLEWARE_CLASSES = (
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.common.CommonMiddleware',
#'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.auth.middleware.SessionAuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware',
'django.middleware.security.SecurityMiddleware',
)

如果要禁用session的话,把上面两个值注释掉就好了

进行迁移。如果没有添加booktest的app,可以使用--empty参数

python manage.py makemigrations --empty booktest
python manage.py migrate

确保数据库中生成django_session表

编写首页

booktest/urls.py

urlpatterns = [
url('^$',views.index), # 路由到views.py中的index()函数
url('^index', views.index, name="index"),
url('^(\d+)$', views.integer),
url('^(?P<p2>\d+)/(?P<p3>\d+)/(?P<p1>\d+)$', views.date),
url('^req$', views.req),
url('^resp$', views.resp),
url('^cookie$', views.cookie),
url('^cookie2$', views.cookie2),
url('^redirect$', views.redirect),
url('^redirect2$', views.redirect2),
url('^session1$', views.session1),
]

booktest/views.py

def session1(request):
uname = None
context = {"uname":uname}
return render(request, 'booktest/session1.html', context)

templates/booktest/session1.html

<body>
欢迎:{{uname}}
<hr/>
<a href="#">登录</a>
<hr/>
<a href="#">退出</a>
</body>

编写登录页面

booktest/urls.py

urlpatterns = [
url('^$',views.index), # 路由到views.py中的index()函数
url('^index', views.index, name="index"),
url('^(\d+)$', views.integer),
url('^(?P<p2>\d+)/(?P<p3>\d+)/(?P<p1>\d+)$', views.date),
url('^req$', views.req),
url('^resp$', views.resp),
url('^cookie$', views.cookie),
url('^cookie2$', views.cookie2),
url('^redirect$', views.redirect),
url('^redirect2$', views.redirect2),
url('^session1$', views.session1),
url('^session2$', views.session2),
]

booktest/views.py

def session2(request):
return render(request, 'booktest/session2.html')

templates/booktest/session1.html

<body>
欢迎:{{uname}}
<hr/>
<a href="/booktest/session2">登录</a>
<hr/>
<a href="#">退出</a>
</body>

templates/booktest/session2.html

<body>
<form method="post" action="/booktest/session2_handler">
<input type="text" name="uname"/>
<input type="submit" value="登录"/>
</form>
</body>

处理登录请求

booktest/urls.py

urlpatterns = [
url('^$',views.index), # 路由到views.py中的index()函数
url('^index', views.index, name="index"),
url('^(\d+)$', views.integer),
url('^(?P<p2>\d+)/(?P<p3>\d+)/(?P<p1>\d+)$', views.date),
url('^req$', views.req),
url('^resp$', views.resp),
url('^cookie$', views.cookie),
url('^cookie2$', views.cookie2),
url('^redirect$', views.redirect),
url('^redirect2$', views.redirect2),
url('^session1$', views.session1),
url('^session2$', views.session2),
url('^session2_handler$', views.session2_handler),
]

booktest/views.py

def session2_handler(request):
post = request.POST
uname = post['uname']
request.session['uname'] = uname
return HttpResponseRedirect('/booktest/session1')

数据库的django_session表中出现了

这里的session_key是故意写的这么复杂,以防重复的。而session_data是经过base64编码的,可以使用 https://base64.supfree.net/ 进行解码

解码后的结果如下:

修改session1,从session中获取值

booktest/views.py

def session1(request):
uname = request.session.get('uname', '未登陆')
context = {"uname":uname}
return render(request, 'booktest/session1.html', context)

登录后,则显示用户名

退出登录

booktest/urls.py

urlpatterns = [
url('^$',views.index), # 路由到views.py中的index()函数
url('^index', views.index, name="index"),
url('^(\d+)$', views.integer),
url('^(?P<p2>\d+)/(?P<p3>\d+)/(?P<p1>\d+)$', views.date),
url('^req$', views.req),
url('^resp$', views.resp),
url('^cookie$', views.cookie),
url('^cookie2$', views.cookie2),
url('^redirect$', views.redirect),
url('^redirect2$', views.redirect2),
url('^session1$', views.session1),
url('^session2$', views.session2),
url('^session2_handler$', views.session2_handler),
url('^session3$', views.session3),
]

booktest/views.py

def session3(request):
request.session['uname'] = None
return HttpResponseRedirect('/booktest/session1')

添加退出登录的链接

templates/booktest/session3.html

<body>
欢迎:{{uname}}
<hr/>
<a href="/booktest/session2">登录</a>
<hr/>
<a href="/booktest/session3">退出</a>
</body>

通过set_expiry()函数设置过期时间。如果没有设置,默认在两个星期后过期

如果你想浏览器退出的时候马上过期,可以设置参数为0

def session2_handler(request):
post = request.POST
uname = post['uname']
request.session['uname'] = uname
request.session.set_expiry(0)
return HttpResponseRedirect('/booktest/session1')

把session保存到redis中

django3/settings.py

SESSION_ENGINE = 'redis_sessions.session'
SESSION_REDIS_HOST = 'localhost'
SESSION_REDIS_PORT = 6379
SESSION_REDIS_DB = 0
SESSION_REDIS_PASSWORD = ''
SESSION_REDIS_PREFIX = 'session'

需要安装插件django-redis-sessions

pip install django-redis-sessions

登录后就可以在redis中查看session的信息了

Django:视图views(三)的更多相关文章

  1. Django基础之视图(views)层、模板层

    目录 Django基础之视图(views)层.模板层 JsonResponse 向前端返回一个json格式字符串的两种方式 重写Django中的json的某个方法 form表单上传文件 FBV与CBV ...

  2. django 中的视图(Views)

    Views Django中views里面的代码就是一个一个函数逻辑, 处理客户端(浏览器)发送的HTTPRequest, 然后返回HTTPResponse, http请求中产生两个核心对象: http ...

  3. django视图函数解析(三)

    1 视图views概述 1 作用: 视图接受web请求并响应web请求 2 本质: 视图就是python中的处理函数 3 响应: 一般是一个网页的HTML内容.一个重定向.错误信息页面.json格式的 ...

  4. 【Django笔记1】-视图(views)与模板(templates)

    视图(views)与模板(templates) 1,视图(views) ​ 将接收到的数据赋值给模板(渲染),再传递给浏览器.HTML代码可以直接放在views.py(文件名可任意更换),也可以放在t ...

  5. Django视图层之路由配置系统(urls)

    视图层之路由配置系统(urls) URL配置(URLconf)就像Django 所支撑网站的目录.它的本质是URL与要为该URL调用的视图函数之间的映射表:你就是以这种方式告诉Django,对于这个U ...

  6. Django视图(一)

    Django视图(一) 一. 概述 作用:视图接受web请求,并相应请求 本质:视图是自定义的一个python中的函数 响应内容:正常视图,重定向视图,错误视图(404,500,400) 响应过程: ...

  7. Django 2.0 学习(07):Django 视图(进阶-续)

    接Django 2.0 学习(06):Django 视图(进阶),我们将聚焦在使用简单的表单进行处理和精简代码. 编写简单表单 我们将用下面的代码,来替换之前的detail模板("polls ...

  8. 【Mac系统 + Python + Django】之开发一个发布会系统【Django视图(二)】

    此学习资料是通过虫师的python接口自动化出的书学习而来的,在此说明一下,想学习更多的自动化的同学可以找虫师的博客园,非广告,因为我python+selenium自动化也是跟虫师学的,学习效果很好的 ...

  9. [diango]理解django视图工作原理

    前言:正确理解django视图view,模型model,模板的概念及其之间的关联关系,才能快速学习并上手使用django制作网页 本文主要讲解自己在学习django后对视图view的理解 在进入正文之 ...

  10. Django 2.0 学习(03):Django视图和URL(下)

    接上篇博文,继续分析Django基本流程. 编写第一个(view)视图函数 1.打开文件polls/views.py,输入下面的Python代码: from django.http import Ht ...

随机推荐

  1. keras 文本分类 LSTM

    首先,对需要导入的库进行导入,读入数据后,用jieba来进行中文分词 # encoding: utf-8 #载入接下来分析用的库 import pandas as pd import numpy as ...

  2. GraphQL,你准备好了么?

    一个多月前,facebook 将其开源了一年多的 GraphQL 标记为 production ready ( http://graphql.org/blog/production-ready/ ), ...

  3. Django TemplateDoesNotExist

    在联系Django的时候,启动正常,我在浏览器上输入URL地址后报错 TemplateDoesNotExist at /test/ 解决方案 默认这里是空的,这里我们填上我们静态文件的地址

  4. elasticsearch中 refresh 和flush区别【转】

    elasticsearch中有两个比较重要的操作:refresh 和 flush refresh操作 当我们向ES发送请求的时候,我们发现es貌似可以在我们发请求的同时进行搜索.而这个实时建索引并可以 ...

  5. npm错误:Error: listen EADDRNOTAVAIL

    错误 Error: listen EADDRNOTAVAIL 127.0.0.1:8080 有两种情况 8080端口被绑定了 地址错误 Error: getaddrinfo ENOTFOUND 域名错 ...

  6. 【GMT43智能液晶模块】例程二:串口通信实验

    实验原理: GMT43智能液晶模块的串口包括USB_UART(CH340),TTL,RS-232,RS-485/ RS-422等四部分,USB_UART部分通过CH340芯片与STM32F429的US ...

  7. vue.js在visual studio 2017下的安装

    1.打开"工具"菜单->"NuGet 包管理器"->"管理解决方案 Nuget 的程序包": 在红色标识的地方输入vue: 2. ...

  8. CTimeSpan

    要获取两个时间差,如两个CTime的时间差,可以使用MFC中的CTimeSpan类. CTime time1 = CTime::GetCurrentTime(); CTime time2 = CTim ...

  9. WPF自定义路由事件(二)

    WPF中的路由事件 as U know,和以前Windows消息事件区别不再多讲,这篇博文中,将首先回顾下WPF内置的路由事件的用法,然后在此基础上自定义一个路由事件. 1.WPF内置路由事件 WPF ...

  10. Math.ceil()、Math.floor()和Math.round()

    下面来介绍将小数值舍入为整数的几个方法:Math.ceil().Math.floor()和Math.round(). 这三个方法分别遵循下列舍入规则: Math.ceil()执行向上舍入,即它总是将数 ...