Django中的cookie和session实现
cookie
from django.shortcuts import render, HttpResponse, redirect # 此装饰器的作用就是讲所有没有cookie验证的页面都需要验证后方可跳转
def login_required(fun):
def inner(request, *args, **kwargs):
if not request.COOKIES.get('is_login') == '':
next = request.path_info
print('next', next)
return redirect('/login/?next={}'.format(next)) # 如果没有cookie,就需要跳转登录页面,但是将此页面的路径拼接到url上
ret = fun(request, *args, **kwargs)
return ret return inner def login(request):
if request.method == 'POST':
print(request.get_full_path())
user = request.POST.get('user')
pwd = request.POST.get('pwd')
if user == '' and pwd == '':
next = request.GET.get('next')
if next:
ret = redirect(next)
else:
ret = redirect('/index/')
ret.set_cookie('is_login', '', max_age=5) # 设置cookie {"is_login": '1'} 存储方式为键值对, max_age = 设置过期时间
return ret
return render(request, 'login.html') @login_required
def index(request):
return render(request, 'index.html') @login_required
def logout(request):
ret = redirect('/login/')
ret.delete_cookie('is_login') # 删除cookie
return ret @login_required
def home(request):
return HttpResponse('这是home页面')
sesson
from django.shortcuts import render, HttpResponse, redirect # 此装饰器的作用就是讲所有没有session验证的页面都需要验证后方可跳转
def login_required(fn):
def inner(request, *args, **kwargs):
if not request.session.get('is_login') == '':
next = request.path_info
return redirect('/login/?next={}'.format(next))
ret = fn(request, *args, **kwargs)
return ret return inner def login(request):
if request.method == 'POST':
user = request.POST.get('user')
pwd = request.POST.get('pwd')
if user == '' and pwd == '':
next = request.GET.get('next')
if next:
ret = redirect(next)
else:
ret = redirect('/index/')
request.session['is_login'] = '' # 设置session
request.session.set_expiry(5) # 设置超时间
return ret
return render(request, 'login.html') @login_required
def home(request):
return HttpResponse('这是home页面') @login_required
def index(request):
print(request.session.session_key) # 获取django_session表中的键
print(request.session.exists('vlqc57dhhm9jiy12c70zyii6bnit6xcv'))
return render(request, 'index.html') def logout(request):
# request.session.delete()
request.session.flush() # 删除该用户的所有数据,删除cookie
ret = redirect('/login/')
return ret
Django中的cookie和session实现的更多相关文章
- {Django基础八之cookie和session}一 会话跟踪 二 cookie 三 django中操作cookie 四 session 五 django中操作session
Django基础八之cookie和session 本节目录 一 会话跟踪 二 cookie 三 django中操作cookie 四 session 五 django中操作session 六 xxx 七 ...
- Django 中的 cookie 和 session
一.cookie 由于HTTP协议是无状态的,而服务器端的业务必须是要有状态的.Cookie诞生的最初目的是为了存储web中的状态信息,以方便服务器端使用.比如判断用户是否是第一次访问网站.目前最新的 ...
- django中操作cookie与session
cookie 什么是Cookie Cookie具体指的是一段小信息,它是服务器发送出来存储在浏览器上的一组组键值对,下次访问服务器时浏览器会自动携带这些键值对,以便服务器提取有用信息. Cookie的 ...
- Django中的Cookie、Session、Token
Cookie : 指望着为了辨别用户身份.进行会话跟踪而存储在用户本地的数据(通常经过加密),是由服务端生成,发送给客户端浏览器,浏览器会将Cookie以key/value保存,下一请求同一网站是就发 ...
- Django中的cookie与session
cookie与session的实现原理 HTTP被设计为”无状态”,每次请求都处于相同的空间中. 在一次请求和下一次请求之间没有任何状态保持,我们无法根据请求的任何方面(IP地址,用户代理等)来识别来 ...
- Django中的cookie和session
前言 HTTP协议 是短连接.且状态的,所以在客户端向服务端发起请求后,服务端在响应头 加入cokie响应给浏览器,以此记录客户端状态: cook是来自服务端,保存在浏览器的键值对,主要应用于用户登录 ...
- 【转】Django中的cookie与session
转自:https://www.cnblogs.com/chenchao1990/p/5283725.html cookie与session的实现原理 HTTP被设计为”无状态”,每次请求都处于相同的空 ...
- 如何使用django中的cookie和session?
1.Cookie 介绍 Cookie是由服务器端生成,发送给User-Agent(一般是浏览器),浏览器会将Cookie的key/value保存到某个目录下的文本文件内,下次请求同一网站时就发送该Co ...
- Django中的Cookie和Session操作以及CBV
1.Cookie 平常我们在浏览网页的时候,在需要输入密码的地方,如果已经登陆了一次,并且时间间隔比较近的话,是不需要登陆的,为什么了?这就是Cookie的作用. Cookie(或Cookies)指某 ...
- python Django中的cookie和session
目录 Cookie 1.1获取Cookie 1.2设置Cookie Session 1.数据库Session 2.缓存Session 3.文件Session 4.缓存+数据库Session Cooki ...
随机推荐
- 【转】面向切面编程-AOP,挺有用的
原文:http://blog.csdn.net/yangzhihello/article/details/40377399 下面的代码有点问题, ins[methodName] = function( ...
- DLL混淆
- Vs2013在Linux开发中的应用(19): 启动gdb
快乐虾 http://blog.csdn.net/lights_joy/ 欢迎转载,但请保留作者信息 1.1 载入调试引擎 因为我们无法干预VC的调试引擎载入.但能够侦听VC的调试引擎载入事件, ...
- Office EXCEL 的绝对引用和相对引用如何理解
比如C1 = A1+B1,则我把C1的单元格往下拖拉的时候,C2会自动等于A2+B2,C3会自动等于A3+B3,而如果让G1 = $E$1+$F$1,则把G1单元格往下拖拉的时候,G2G3单元格都不会 ...
- centos中w使用smbclient连接window出现:session setup failed: NT_STATUS_LOGON_FAILURE
1. 在window中网络->我自己的电脑->能够查看到共享文件,说明window的共享是正常了; 2. 在window中配置共享时,使用的是仅仅同意超级管理员訪问,可是我把超级管理员改名 ...
- QT学习笔记(一)——ui的认识
////////////2015/08/06/////////////////// ///////////by xbw////////////////////////// //////////环境 Q ...
- make eval builtin function
1 eval的返回值是空字符串,因此它可以用于Makefile的任何位置而不引起错误 2 eval函数的作用效果 生成Makefile的动态部分,即eval用于增加Makefile的构成部分. 也就是 ...
- 较大主干网的ISP通常控制信道利用率不超过50%
信道利用率 网络利用率 加权平均值
- Genymotion设置网络桥接
1,打开Genymotion,找到对应的模拟器,点击“设置”按钮 2,在网络选项中选择桥接 Bridge
- method.invoke()使用
public Object invoke(Object obj, Object... args) throws IllegalAccessException, IllegalArgumentExcep ...