cookie、session与用户认证组件
1.cookie
def login(request):
if request.method == "GET":
return render(request,"login.html")
else:
user = request.POST.get("user")
pwd = request.POST.get("pwd")
user_obj = UserInfo.objects.filter(user=user,pwd=pwd).first()
if user_obj:
# 如果登录成功设置cookie
obj = redirect("/index/")
obj.set_cookie("username",user)
obj.set_cookie("is_login",True,max_age=3600*24*7)
return obj
else:
return HttpResponse("error") def index(request): print(request.COOKIES)
is_login = request.COOKIES.get("is_login")
if not is_login:
return redirect("/login/")
shangpin = "香蕉"
shangpin_list = ["苹果", "荔枝", "榴莲"]
name = request.COOKIES.get("username")
return render(request,"index.html",{"shangpin":shangpin,
"shangpin_list":shangpin_list,
"name":name})
2.session
def login_session(request):
if request.method == "GET":
return render(request,"login.html")
else:
user = request.POST.get("user")
pwd = request.POST.get("pwd")
user_obj = UserInfo.objects.filter(user=user,pwd=pwd).first()
if user_obj:
#用户认证信息储存
request.session["suername"] = user
request.session["sis_login"] = True
'''
if request.COOKIE.get("sessionid"):
random_str = request.COOKIE.get("sessionid")
在django-session表中过滤session-key=random-str的记录进行update
else:
1.生成一个随机字符串
2.向django-session表中插入数据
3.响应set_cookie:{"sessionid": }
'''
return redirect("/index_session/")
else:
return HttpResponse("error")
def index_session(request):
'''
request.session
1.request.COOKIE.get("sessionid")
2.在django-session表中过滤session-key
3.取出过滤记录的session-data反序列化数据字典 {"susername":"egon","sis_login":True}
'''
sis_login = request.session.get("sis_login")
if not sis_login:
return redirect("/login_session/")
else:
shangpin = "香蕉"
shangpin_list = ["苹果", "荔枝", "榴莲"]
name = request.session.get("susername")
return render(request, "index.html", {"shangpin": shangpin,
"shangpin_list": shangpin_list,
"name": name})
def logout(request):
'''
1 request.COOKIE.get("sessionid") :23423hkjsf890234sd
2 在django-session表过滤session-key=23423hkjsf890234sd的记录删除
3 response.delete_cookie("sessionid")
'''
request.session.flush()
return redirect("/login_session/")
3.用户认证组件
前提:使用django自带的用户表 auth_user
插入记录命令:python manage.py createsuperuser
引入from django.contrib import auth
1.auth.authenticate(username=user,password=pwd) 查询语句
2.auth.login(request,user_obj) 保存用户状态信息
request.user:全局变量。模板,视图直接可以使用
3.auth.logout(request) 注销
4.User.objects.create_user(username=user,password=pwd) 注册 from django.contrib.auth.models import User
5.user = User.objects.get(username=request.user.username)
user.set_password(raw_password="555")
from django.shortcuts import render,redirect,HttpResponse # Create your views here.
from django.contrib import auth def login(request):
if request.method == "GET":
return render(request,"login.html")
else:
user = request.POST.get("user")
pwd = request.POST.get("pwd")
# 数据库查询该用户是否存在
user_obj = auth.authenticate(username=user,password=pwd)
if user_obj:
# 保存用户状态信息
auth.login(request,user_obj) # request.session["user_id"]=user_obj.pk
return redirect("/index/")
else:
return redirect("/login/") def index(request):
'''
print(request.user) # 默认匿名用户对象 AnonymousUser
print(request.user.id) # None
print(request.user.username) # ""
print(request.user.is_active) # False '''
if not request.user.is_authenticated:
return redirect("/login/")
name = request.user.username
return render(request,"index.html",locals()) def logout(request):
auth.logout(request)
return redirect("/login/") from django.contrib.auth.models import User
def reg(request):
if request.method =="GET":
return render(request,"reg.html")
else:
user = request.POST.get("user")
pwd = request.POST.get("pwd")
User.objects.create_user(username=user,password=pwd)
return redirect("/login/") def set_password(request):
user = User.objects.get(username=request.user.username)
user.set_password(raw_password="")
user.save()
return redirect("/login/")
user.save()
cookie、session与用户认证组件的更多相关文章
- Django组件 - cookie、session、用户认证组件
一.cookie 1.会话跟踪技术 1)什么是会话跟踪技术 我们需要先了解一下什么是会话!可以把会话理解为客户端与服务器之间的一次会晤,在一次会晤中可能会包含多次请求和响应.例如你给10086打个电话 ...
- cookie,session,用户认证组件
一. 绘画跟踪技术 在客户端与服务端的一次会务中,多次的请求与相应,HTTP协议是无状态协议,也就是说每个请求都是独立的!无法记录前一次请求的状态.会话跟踪技术即能够实现多次回话间信息共享的作用,HT ...
- python 全栈开发,Day79(Django的用户认证组件,分页器)
一.Django的用户认证组件 用户认证 auth模块 在进行用户登陆验证的时候,如果是自己写代码,就必须要先查询数据库,看用户输入的用户名是否存在于数据库中: 如果用户存在于数据库中,然后再验证用户 ...
- 061.Python前端Django组件用户认证组件
一 auth认证组件 在使用pymysql,数据库迁移的时候.,默认生成有十张表如下 查看author_user表结构 mysql> desc auth_user; +------------- ...
- web框架开发-Django用户认证组件
可以用认证组件做什么 针对session的缺陷, 跟新数据时,不跟新key键, 用户认证组件是删除后再重建 用户认证组件很多功能可以直接使用 利用用户认证表(auth_user,通过Django自己创 ...
- django - 总结 - 用户认证组件
用户认证组件 from django.contrib import auth 从auth_user表中获取对象,没有返回None,其中密码为密文,使用了加密算法 user = auth.authent ...
- 10.Django用户认证组件
用户认证组件: 功能:用session记录登录验证状态: 前提:用户表,django自带的auth_user 创建超级用户:python manage.py createsuperuser ...
- Django用户认证组件
用户认证 主要分两部分: 1.auth模块 from django.contrib import auth 2.User对象 from django.contrib.auth.models imp ...
- django的用户认证组件
DataSource:https://www.cnblogs.com/yuanchenqi/articles/9064397.html 代码总结: 用户认证组件: 功能:用session记录登录验证状 ...
随机推荐
- Windows 2016 服务器安全配置和加固
最近一个项目需要使用Windows服务器,选择安装了最新版的Windows 2016,上一次使用Windows服务器还是Windows 2003系统,发现变化还是挺多的,依次记录下来以备后面查阅. 目 ...
- Swoole练习 websocket
WEBSOCKET 服务端代码 //创建websocket服务器对象,监听0.0.0.0:9502端口 $ws = new swoole_websocket_server("0.0.0.0& ...
- unix 命令
ubuntu 命令窗口的打开 打开命令行窗口: Ctrl+Alt+T 在打开的命令行窗口中打开一个新的Tab: Ctrl+Shift+T 在同一窗口的Tab间切换: Ctrl+Page Up 或者 ...
- JavaScript控制浏览器全屏及各种浏览器全屏模式的方法、属性和事件
实现全屏 个人版:function isFullScreen() { var fullscreenElement = document.fullscreenElement || document.we ...
- LeetCode 746. 使用最小花费爬楼梯(Min Cost Climbing Stairs) 11
746. 使用最小花费爬楼梯 746. Min Cost Climbing Stairs 题目描述 数组的每个索引做为一个阶梯,第 i 个阶梯对应着一个非负数的体力花费值 cost[i].(索引从 0 ...
- SQL Server 数据库清空ldf日志文件
USE [master] ALTER DATABASE [DB_Develop] SET RECOVERY SIMPLE WITH NO_WAIT ALTER DATABASE [DB_Develop ...
- 字典的学习3——嵌套——Python编程从入门到实践
嵌套 ? 一系列字典存储在列表or列表作为值存储在字典or字典中套字典 1. 字典列表 alien_0 = {'color': 'green', 'points': 5} alien_1 = {'co ...
- WUSTOJ 1319: 球(Java)并查集
题目链接:1319: 球 参考:wustoj 1319 球-wust_tanyao,并查集 并查集系列:WUSTOJ 1346: DARK SOULS(Java)并查集 Description Icy ...
- Linux中光标消失解决办法
假如Linux下光标消失,不要急: echo -e "\033[?25l" 隐藏光标 echo -e "\033[?25h" 显示光标 (转载自:https: ...
- Python之推导式笔记
观察下面的代码: list1 = [] for i in range(10): list1.append(i) print(list1) 作为一个Java出身的程序员,我一定会这么写代码去生成一个列表 ...