django设置cookie和session
1 设置cookie
本例中应用名称为cookie
模型model
from django.db import models
from django.db import models
class UserInfo(models.Model):
username = models.CharField(max_length=64)
password = models.CharField(max_length=64)
数据库迁移
python manage.py makemigrations
python manage.py migrate
给数据库添加数据
路由urls
from django.contrib import admin
from django.urls import path
from cookie import views urlpatterns = [
path('admin/', admin.site.urls),
path('login/', views.login),
path('index/', views.index),
]
视图函数
from django.shortcuts import render, redirect, HttpResponse
from cookie import models def login(request):
ret = ""
if request.method == "POST":
user = request.POST.get("user")
pwd = request.POST.get("pwd")
# 查询数据库中的用户名和密码
user_obj = models.UserInfo.objects.filter(username=user, password=pwd).first()
if user_obj:
"""
如果验证通过,则重定向至index并设置cookie
"""
obj = redirect("/index/")
obj.set_cookie("is_login", True, 30) # cookie有效期为30秒
obj.set_cookie("username", user_obj.username)
return obj
else:
ret = "用户名或密码错误"
return render(request, "login.html", {"ret": ret}) def index(request):
is_login = request.COOKIES.get("is_login")
username = request.COOKIES.get("username")
if not is_login:
return redirect("/login/")
return render(request, "index.html", {
"user": username
})
模板页面
登录页面 login.html
<body>
<h3>用户登录页面</h3>
<form action="/login/" method="post">
{% csrf_token %}
<p>用户名:<input type="text" name="user"></p>
<p>密码:<input type="password" name="pwd"></p>
<p><span>{{ ret }}</span></p>
<input type="submit" value="登录" class="sub_btn">
</form>
</body>
首页index.html
<body>
<h3>这是index页面。你好 {{ user }}</h3>
</body>
下来访问测试一下
点击登录
可以看到,已经按预想跳转至index页面
下来看看设置的cookie
再来看看,重定向访问时携带的cookie值
2 设置session
创建应用
python manage.py startapp session
注册应用
设置settings.py
INSTALLED_APPS = [
...
'cookie.apps.CookieConfig',
'session.apps.SessionConfig'
]
路由urls
.....
from session import views as session_views urlpatterns = [
......
path('session_login', session_views.session_login),
path('session_index', session_views.session_index),
path('session_logout', session_views.session_logout),
]
视图函数
from django.shortcuts import render, redirect
from cookie import models # 由于要用到数据,所有要吃cookie应用里面导入 def session_login(request):
ret = ""
if request.method == "POST":
user = request.POST.get("user")
pwd = request.POST.get("pwd")
user_obj = models.UserInfo.objects.filter(username=user, password=pwd).first()
if user_obj:
"""
如果验证通过,则设置session,并返回session_index
"""
request.session["is_login"] = True
request.session["username"] = user_obj.username
obj = redirect("/session_index/")
return obj
else:
ret = "用户名或密码错误"
return render(request, "session_login.html", {"ret": ret})
def session_index(request):
is_login = request.session.get("is_login")
username = request.session.get("username")
if not is_login:
"""如果没有登录则跳转至登录页面"""
return redirect("/session_login") return render(request, "session_index.html", {"user": username}) def session_logout(request):
request.session.flush()
return redirect("/session_login/")
模板页面
session_index.html
<h3>基于session的用户登录</h3>
<form action="/session_login/" method="post">
{% csrf_token %}
<p>用户名:<input type="text" name="user"></p>
<p>密码:<input type="password" name="pwd"></p>
<p><span>{{ ret }}</span></p>
<input type="submit" value="登录" class="sub_btn">
</form>
session_index.html
<body>
<h3>这是session_index页面。</h3>
<h3>你好 {{ user }}</h3>
<a href="/session_logout/">注销</a>
</body>
下来测试
可以看到数据库中session表已经有数据了,session_key为随机生成的,为请求时携带的cookie键,session_data为
request.session["is_login"] = True
request.session["username"] = user_obj.username,经过某种算法加密后的数
再来看看页面
django设置cookie和session的更多相关文章
- Django之Cookie、Session、CSRF、Admin
Django之Cookie.Session.CSRF.Admin Cookie 1.获取Cookie: 1 2 3 4 5 6 request.COOKIES['key'] request.get ...
- [py][mx]django的cookie和session操作-7天免登录
浏览器同源策略(same-origin policy) csrf攻击防御核心点总结 django的cookie和session操作-7天免登录 flask操作cookie&django的see ...
- Django基础cookie和session
Django基础cookie和session 1.会话跟踪 什么是会话!可以把会话理解为客户端与服务器之间的一次会晤,在一次会晤中可能会包含多次请求和响应.例如给10086打个电话,你就是客户端, ...
- django 中 cookie与session 相关的知识
cookie :它是一个字典
- django的cookie和session以及内置信号、缓存
cookie和session cookie和session的作用: cookie和session都记录了客户端的某种状态,用来跟踪用户访问网站的整个回话.两者最大的区别是cookie的信息是存放在浏览 ...
- django的cookie 和session
Cookie 1.获取cookie: request.COOKIES['key'] request.get_signed_cookie(key, default=RAISE_ERROR, salt=' ...
- Django组件-cookie与session
一.会话跟踪技术 1.什么是会话跟踪技术 我们需要先了解一下什么是会话!可以把会话理解为客户端与服务器之间的一次会晤,在一次会晤中可能会包含多次请求和响应.例如你给10086打个电话,你就是客户端,而 ...
- web框架开发-Django组件cookie与session
http协议的每一次都是无保存状态的请求,这会带来很多的不方便,比如,一刷新网页,或者进入该网页的其他页面,无法保存之前的登录状态.为了解决类似这样的问题,引入了会话跟踪 会话跟踪技术 1 什么是会话 ...
- Django 之 cookie和session
一. Cookie 1.Cookie的由来 因为HTTP协议是无状态的,无状态的意思就是每次请求都是独立的,它的执行情况和结果与前面的请求和之后的请求都无直接关系,也不会受前后请求响应情况直接影响.简 ...
随机推荐
- springboot 整合 elasticsearch
1引入jar包 <!--elasticsearch--> <dependency> <groupId>org.springframework.boot</gr ...
- 马士兵Spring-声明式事务管理-annotation
1.事务加在DAO层还是service层? service中可能多涉及多种DAO的操作,比如存了一个User之后,需要保存一条日志信息:如果在DAO中分别设置事务的话,一个DAO下面方法抛出异常了,但 ...
- 怎么才知道你在使用的是不是中国电信CN2的线路
原文:http://www.juzhenyun.org/helpview_66.html 首先你能从和电信的合同上确认是否为CN2线路 目前CN2的线路多为商业用途.公司用户申请中国电信的Intern ...
- c# 类间关系
一.依赖关系 简单的理解,依赖就是一个类A使用到了另一个类B,而这种使用关系是具有偶然性的.临时性的.非常弱的,但是类B的变化会影响到类A.比如某人要过河,需要借用一条船,此时人与船之间的关 ...
- WPF DatePicker 默认显示当前时间
两种方法: 1.通过后台赋值: this.datePicker.SelectedDate = DateTime.Now; 2.前台控件的属性直接赋值 xmlns:sys="clr-names ...
- 让别人能登陆你的mysql
线上的数据库肯定是不能轻易在开发新功能的时候动的,如果你的数据库跟线上不一样了又没有新数据库的备份,就很麻烦. 当然去动线上数据库,出了什么问题我是不想背锅的. 最稳健的办法!让管理线上数据库的同学, ...
- 分享 - 普通程序员如何转向AI方向
原作者:计算机的潜意识 原文链接,内容稍有改动,侵删 1. 目的2. AI领域简介3. 学习方法4. 学习路线 0) 领域了解1) 知识准备2) 机器学习3) 实践做项目4) 深度学习5) 继续机器学 ...
- MyBatis 注解式开发
- node.js中实现同步操作的3种实现方法
这篇文章主要介绍了node.js中实现同步操作的3种实现方法,本文用实例讲解一些需要同步操作的情况下,如何编程实现,需要的朋友可以参考下 众所周知,异步是得天独厚的特点和优势,但同时在程序中同步的需求 ...
- Python Modules
[Python Modules] 1. a module is a python source file. 2. a package is a directory with a __init__.py ...