在Python的Django框架的视图中使用Session的方法


Posted in Python onJuly 23, 2015

SessionMiddleware 激活后,每个传给视图(view)函数的第一个参数``HttpRequest`` 对象都有一个 session 属性,这是一个字典型的对象。 你可以象用普通字典一样来用它。 例如,在视图(view)中你可以这样用:

# Set a session value:
request.session["fav_color"] = "blue"

# Get a session value -- this could be called in a different view,
# or many requests later (or both):
fav_color = request.session["fav_color"]

# Clear an item from the session:
del request.session["fav_color"]

# Check if the session has a given key:
if "fav_color" in request.session:
 ...

其他的映射方法,如 keys() 和 items() 对 request.session 同样有效:

下面是一些有效使用Django sessions的简单规则:

    用正常的字符串作为key来访问字典 request.session , 而不是整数、对象或其它什么的。

    Session字典中以下划线开头的key值是Django内部保留key值。 框架只会用很少的几个下划线 开头的session变量,除非你知道他们的具体含义,而且愿意跟上Django的变化,否则,最好 不要用这些下划线开头的变量,它们会让Django搅乱你的应用。

    比如,不要象这样使用`` _fav_color`` 会话密钥(session key):

request.session['_fav_color'] = 'blue' # Don't do this!

    不要用一个新对象来替换掉 request.session ,也不要存取其属性。 可以像Python中的字典那样使用。 例如:

request.session = some_other_object # Don't do this!

request.session.foo = 'bar' # Don't do this!

我们来看个简单的例子。 这是个简单到不能再简单的例子:在用户发了一次评论后将has_commented设置为True。 这是个简单(但不很安全)的、防止用户多次评论的方法。

def post_comment(request):
 if request.method != 'POST':
  raise Http404('Only POSTs are allowed')

 if 'comment' not in request.POST:
  raise Http404('Comment not submitted')

 if request.session.get('has_commented', False):
  return HttpResponse("You've already commented.")

 c = comments.Comment(comment=request.POST['comment'])
 c.save()
 request.session['has_commented'] = True
 return HttpResponse('Thanks for your comment!')

下面是一个很简单的站点登录视图(view):

def login(request):
 if request.method != 'POST':
  raise Http404('Only POSTs are allowed')
 try:
  m = Member.objects.get(username=request.POST['username'])
  if m.password == request.POST['password']:
   request.session['member_id'] = m.id
   return HttpResponseRedirect('/you-are-logged-in/')
 except Member.DoesNotExist:
  return HttpResponse("Your username and password didn't match.")

下面的例子将登出一个在上面已通过`` login()`` 登录的用户:

def logout(request):
 try:
  del request.session['member_id']
 except KeyError:
  pass
 return HttpResponse("You're logged out.")

注意

在实践中,这是很烂的用户登录方式,稍后讨论的认证(authentication )框架会帮你以更健壮和有利的方式来处理这些问题。 这些非常简单的例子只是想让你知道这一切是如何工作的。 这些实例尽量简单,这样你可以更容易看到发生了什么
设置测试Cookies

就像前面提到的,你不能指望所有的浏览器都可以接受cookie。 因此,为了使用方便,Django提供了一个简单的方法来测试用户的浏览器是否接受cookie。 你只需在视图(view)中调用 request.session.set_test_cookie(),并在后续的视图(view)、而不是当前的视图(view)中检查 request.session.test_cookie_worked() 。

虽然把 set_test_cookie() 和 test_cookie_worked() 分开的做法看起来有些笨拙,但由于cookie的工作方式,这无可避免。 当设置一个cookie时候,只能等浏览器下次访问的时候,你才能知道浏览器是否接受cookie。

检查cookie是否可以正常工作后,你得自己用 delete_test_cookie() 来清除它,这是个好习惯。 在你证实了测试cookie已工作了之后这样操作。

这是个典型例子:

def login(request):

 # If we submitted the form...
 if request.method == 'POST':

  # Check that the test cookie worked (we set it below):
  if request.session.test_cookie_worked():

   # The test cookie worked, so delete it.
   request.session.delete_test_cookie()

   # In practice, we'd need some logic to check username/password
   # here, but since this is an example...
   return HttpResponse("You're logged in.")

  # The test cookie failed, so display an error message. If this
  # were a real site, we'd want to display a friendlier message.
  else:
   return HttpResponse("Please enable cookies and try again.")

 # If we didn't post, send the test cookie along with the login form.
 request.session.set_test_cookie()
 return render_to_response('foo/login_form.html')

注意

再次强调,内置的认证函数会帮你做检查的。

 

Python 相关文章推荐
跟老齐学Python之玩转字符串(2)
Sep 14 Python
在Python中使用M2Crypto模块实现AES加密的教程
Apr 08 Python
Python书单 不将就
Jul 11 Python
python模拟菜刀反弹shell绕过限制【推荐】
Jun 25 Python
Flask配置Cors跨域的实现
Jul 12 Python
django迁移文件migrations的实现
Mar 31 Python
Spring @Enable模块驱动原理及使用实例
Jun 23 Python
Python如何执行精确的浮点数运算
Jul 31 Python
15个应该掌握的Jupyter Notebook使用技巧(小结)
Sep 23 Python
解决python存数据库速度太慢的问题
Apr 23 Python
python代码实现扫码关注公众号登录的实战
Nov 01 Python
Python Django获取URL中的数据详解
Nov 01 Python
详解Python的Django框架中的Cookie相关处理
Jul 22 #Python
在Django中使用Sitemap的方法讲解
Jul 22 #Python
用Python的Django框架来制作一个RSS阅读器
Jul 22 #Python
利用Python的Django框架生成PDF文件的教程
Jul 22 #Python
在Python的Django框架中生成CSV文件的方法
Jul 22 #Python
在主机商的共享服务器上部署Django站点的方法
Jul 22 #Python
在Lighttpd服务器中运行Django应用的方法
Jul 22 #Python
You might like
一个简单且很好用的php分页类
2013/10/26 PHP
php过滤html中的其他网站链接的方法(域名白名单功能)
2014/04/24 PHP
PHP数组去重的更快实现方式分析
2018/05/09 PHP
Sample script that displays all of the users in a given SQL Server DB
2007/06/16 Javascript
保证JavaScript和Asp、Php等后端程序间传值编码统一
2009/04/17 Javascript
extjs fckeditor集成代码
2009/05/10 Javascript
Javascript 继承实现例子
2009/08/12 Javascript
IE网页js语法错误2行字符1、FF中正常的解决方法
2013/09/09 Javascript
JSON传递bool类型数据的处理方式介绍
2013/09/18 Javascript
浅谈JavaScript字符集
2014/05/22 Javascript
利用node.js搭建简单web服务器的方法教程
2017/02/20 Javascript
JS ES6中setTimeout函数的执行上下文示例
2017/04/27 Javascript
关于bootstrap日期转化,bootstrap-editable的简单使用,bootstrap-fileinput的使用详解
2017/05/12 Javascript
JS使用数组实现的队列功能示例
2019/03/04 Javascript
浅谈JavaScript面向对象--继承
2019/03/20 Javascript
jquery ajax 请求小技巧实例分析
2019/11/11 jQuery
JavaScript手写数组的常用函数总结
2020/11/22 Javascript
[03:47]2015国际邀请赛第三日现场精彩回顾
2015/08/08 DOTA
python列表操作使用示例分享
2014/02/21 Python
python网络编程学习笔记(七):HTML和XHTML解析(HTMLParser、BeautifulSoup)
2014/06/09 Python
基于python元祖与字典与集合的粗浅认识
2017/08/23 Python
详谈Python高阶函数与函数装饰器(推荐)
2017/09/30 Python
flask + pymysql操作Mysql数据库的实例
2017/11/13 Python
python pandas dataframe 按列或者按行合并的方法
2018/04/12 Python
通过python实现弹窗广告拦截过程详解
2019/07/10 Python
django的autoreload机制实现
2020/06/03 Python
如何使用scrapy中的ItemLoader提取数据
2020/09/30 Python
多个版本的python共存时使用pip的正确做法
2020/10/26 Python
汽车制造与装配专业自荐信范文
2014/01/02 职场文书
党的群众路线教育实践活动对照检查材料(个人)
2014/09/24 职场文书
乡镇党员干部群众路线对照检查材料思想汇报
2014/09/28 职场文书
抗洪救灾标语
2014/10/08 职场文书
老人节标语大全
2014/10/08 职场文书
本科毕业论文导师评语
2014/12/31 职场文书
个人工作保证书
2015/02/28 职场文书
关于销售人员的年终工作总结要点
2019/08/15 职场文书