django项目搭建与Session使用详解


Posted in Python onOctober 10, 2018

前言

Django完全支持也匿名会话,简单说就是使用跨网页之间可以进行通讯,比如显示用户名,用户是否已经发表评论。session框架让你存储和获取访问者的数据信息,这些信息保存在服务器上(默认是数据库中),以 cookies 的方式发送和获取一个包含 session ID的值,并不是用cookies传递数据本身。

本文给大家详细介绍了关于django项目搭建与Session使用的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧

django+session+中间件

一、使用命令行创建django项目

在指定路径下创建django项目

django-admin startproject djangocommon

在项目目录下 创建app

cd djangocommon
python manage.py startapp commoncore(django-admin startapp commoncore)

django项目搭建与Session使用详解

新增static文件夹和templates文件夹,static---用于存储静态文件,例如js、css、image、txt等文件,templates用于存储项目中需要使用的模板文件,例如html。

最终项目目录如下:

django项目搭建与Session使用详解

修改settings文件,新增:

注意在settings文件中的变量,必须全部用大写

STATIC_ROOT = ''
STATIC_URL = '/static/'
STATICFILES_DIRS = ( os.path.join(os.path.dirname(__file__), '../static/').replace('\\', '/'),)

===================================================================================================

TEMPLATES中指定路由检索 路径DIRS为:[BASE_DIR + "/templates", ]

--------------

TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
'DIRS': [BASE_DIR + "/templates", ],
'APP_DIRS': True,
'OPTIONS': {
'context_processors': [
'django.template.context_processors.debug',
'django.template.context_processors.request',
'django.contrib.auth.context_processors.auth',
'django.contrib.messages.context_processors.messages',
],
},
},
]

================================================================================

DATABASES项设定项目依赖的存储介质,可以指定为文件、内存、数据库。这里我们采用默认的sqlite3数据库

=================================================================================

在INSTALLED_APPS中新增上面新建的app:commoncore

----------------

INSTALLED_APPS = [
 'django.contrib.admin',
 'django.contrib.auth',
 'django.contrib.contenttypes',
 'django.contrib.sessions',
 'django.contrib.messages',
 'django.contrib.staticfiles',
 'commoncore',
]

=============================================================

在djangocommon项目下新增py 命名为view,在这里写后台请求的处理。并在urls文件中配置路由

至此,一个小型的django项目已搭建完成

二、配置session

django的session可以分为内存缓存存储、文件存储、数据库存储。这里我们采用数据库存储。

django项目默认是开启session的,默认存储方式为:SESSION_ENGINE='django.contrib.sessions.backends.db'
(本地缓存:SESSION_ENGINE='django.contrib.sessions.backends.cache' 混合缓存:SESSION_ENGINE='django.contrib.sessions.backends.cached_db'

当然也可以是redis缓存:

CACHES = {"default": {"BACKEND": "django_redis.cache.RedisCache", "LOCATION": "redis://ip:端口/",
"OPTIONS": {"CLIENT_CLASS": "django_redis.client.DefaultClient", }}}
SESSION_ENGINE = "django.contrib.sessions.backends.cache"
SESSION_CACHE_ALIAS = "default"

=======================================================================================================================================

我们这里使用django自带的sqlite存储session,settings配置如下:

SESSION_COOKIE_SECURE = False
SESSION_COOKIE_HTTPONLY = True
SESSION_COOKIE_NAME = 'xxxx'
SEESION_EXPIRE_AT_BROWSER_CLOSE = True
SESSION_COOKIE_AGE = 18000

这里的设定的时间作用不大,可以直接在代码里指定时间:request.session.set_expiry(0) 参数0代表退出浏览器session即失效,单位均为毫秒

中间件MIDDLEWARE_CLASSES中查看是否有'django.contrib.sessions.middleware.SessionMiddleware' 没有的话添加即可

==========================================================================================================

这里我们已经设置好了django session的环境,我们需要使用django自带的模块处理session值

这里需要强调一点,用sqlite数据库存储session需要初始化下数据库,在manage.py文件所在目录下执行命令:

python manage.py makemigrations(python manage.py migrate)

django项目搭建与Session使用详解

打开sqlite,结构如下:

django项目搭建与Session使用详解

至此,session准备工作已经完成。但是需要注意的是session失效,只是时间上失效,其值还是存在库中,因此需要定期删除,也可以在代码中逻辑删除,具体代码如下:

# coding=utf-8
import sys

reload(sys)
sys.setdefaultencoding('utf-8')
import datetime
from django.contrib.sessions.backends.db import SessionStore
from django.contrib.sessions.models import Session


def delsession(key):
if key is None:
return
store = SessionStore()
store.delete(key)
count = Session.objects.all().count()
if count > 20:
nowtime = datetime.datetime.now()
outdatesession = Session.objects.filter(expire_date__lt=nowtime)
for item in outdatesession:
store.delete(item.session_key)


def delovertimesession():
store = SessionStore()
count = Session.objects.all().count()
if count > 20:
nowtime = datetime.datetime.now()
outdatesession = Session.objects.filter(expire_date__lt=nowtime)
for item in outdatesession:
store.delete(item.session_key)

===============================================================================================================================

三、请求的中间件

安全认证、请求过滤以及session的初始值 我们可以在中间件中处理。

在djangocommon项目下,新增middlehttp.py文件,代码大致如下:

reload(sys)
sys.setdefaultencoding('utf-8')

from django.shortcuts import render_to_response


# process_request -------- 接受request之后确定view之前执行
# process_view 确定view之后 并且在view真正执行之前执行
# process_response view执行之后
# process_exception(self, request, exception) view抛出异常

class LoginRequiredMiddleware:
 def process_request(self, request): 
  path = request.path_info.strip('/')
  #这里写处理逻辑和请求控制

在settings文件中的中间件配置MIDDLEWARE_CLASSES中添加'djangocommon.middlehttp.LoginRequiredMiddleware' 如下:

MIDDLEWARE_CLASSES = [
 'django.middleware.security.SecurityMiddleware',
 'django.contrib.sessions.middleware.SessionMiddleware',
 'django.middleware.common.CommonMiddleware',
 'django.middleware.csrf.CsrfViewMiddleware',
 'django.contrib.auth.middleware.AuthenticationMiddleware',
 'django.contrib.auth.middleware.SessionAuthenticationMiddleware', 'djangocommon.middlehttp.LoginRequiredMiddleware',
 'django.contrib.messages.middleware.MessageMiddleware',
 'django.middleware.clickjacking.XFrameOptionsMiddleware',
]

注意顺序,必须在SessionMiddleware之后。

=========================================================================================================================

至此,一个完整的django+session+中间件 项目搭建完成。前后端分离的项目,也可以以此为基础,通过webpack或cli 搭建 编译生成的templates及静态文件即可。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Python 相关文章推荐
python回溯法实现数组全排列输出实例分析
Mar 17 Python
Python将阿拉伯数字转换为罗马数字的方法
Jul 10 Python
Windows下Python使用Pandas模块操作Excel文件的教程
May 31 Python
Python实现删除列表中满足一定条件的元素示例
Jun 12 Python
Python读取本地文件并解析网页元素的方法
May 21 Python
OpenCV+python手势识别框架和实例讲解
Aug 03 Python
Python3安装psycopy2以及遇到问题解决方法
Jul 03 Python
对Python函数设计规范详解
Jul 19 Python
Python动态导入模块:__import__、importlib、动态导入的使用场景实例分析
Mar 30 Python
Python爬虫:Request Payload和Form Data的简单区别说明
Apr 30 Python
Pytorch mask-rcnn 实现细节分享
Jun 24 Python
python zip()函数的使用示例
Sep 23 Python
Python 变量类型详解
Oct 10 #Python
Python中几种属性访问的区别与用法详解
Oct 10 #Python
Python的argparse库使用详解
Oct 09 #Python
详解Python3中的迭代器和生成器及其区别
Oct 09 #Python
不知道这5种下划线的含义,你就不算真的会Python!
Oct 09 #Python
详解利用django中间件django.middleware.csrf.CsrfViewMiddleware防止csrf攻击
Oct 09 #Python
详解如何将python3.6软件的py文件打包成exe程序
Oct 09 #Python
You might like
PHP生成静态HTML页面最简单方法示例
2015/04/09 PHP
php正则表达式学习笔记
2015/11/13 PHP
PHP重置数组为连续数字索引的几种方式总结
2018/03/12 PHP
Laravel框架控制器,视图及模型操作图文详解
2019/12/04 PHP
TP5框架实现签到功能的方法分析
2020/04/05 PHP
javascript 按回车键相应按钮提交事件
2009/11/02 Javascript
Js setInterval与setTimeout(定时执行与循环执行)的代码(可以传入参数)
2010/06/11 Javascript
精心挑选的15个jQuery下拉菜单制作教程
2012/06/15 Javascript
JavaScript实现表格排序方法
2013/06/14 Javascript
简介JavaScript中valueOf()方法的使用
2015/06/05 Javascript
JavaScript中数组添加值和访问值常见问题
2016/02/06 Javascript
javascript移动开发中touch触摸事件详解
2016/03/18 Javascript
浅谈js中的in-for循环
2016/06/28 Javascript
基于touch.js手势库+zepto.js插件开发图片查看器(滑动、缩放、双击缩放)
2016/11/17 Javascript
jQuery和JavaScript节点插入元素的方法对比
2016/11/18 Javascript
BootStrap Fileinput上传插件使用实例代码
2017/07/28 Javascript
本地存储localStorage用法详解
2017/07/31 Javascript
微信小程序实现左右联动的实战记录
2018/07/05 Javascript
vue服务端渲染缓存应用详解
2018/09/12 Javascript
JavaScript对JSON数组简单排序操作示例
2019/01/31 Javascript
jQuery层叠选择器用法实例分析
2019/06/28 jQuery
[00:33]2016完美“圣”典风云人物:Sccc宣传片
2016/12/03 DOTA
[01:09:16]DOTA2-DPC中国联赛 正赛 SAG vs Dynasty BO3 第一场 1月25日
2021/03/11 DOTA
Python中使用OpenCV库来进行简单的气象学遥感影像计算
2016/02/19 Python
Python 'takes exactly 1 argument (2 given)' Python error
2016/12/13 Python
Python使用到第三方库PyMuPDF图片与pdf相互转换
2019/05/03 Python
Django 迁移、操作数据库的方法
2019/08/02 Python
python自动化UI工具发送QQ消息的实例
2019/08/27 Python
Python:type、object、class与内置类型实例
2019/12/25 Python
详解HTML5.2版本带来的修改
2020/05/06 HTML / CSS
幼儿园教师奖惩制度
2014/02/01 职场文书
不打扫卫生检讨书
2014/02/12 职场文书
2014年招商引资工作总结
2014/11/22 职场文书
求职自我评价怎么写
2015/03/09 职场文书
go类型转换及与C的类型转换方式
2021/05/05 Golang
SqlServer常用函数及时间处理小结
2023/05/08 SQL Server