经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » Django » 查看文章
django session完成状态保持的方法
来源:jb51  时间:2018/11/28 9:32:21  对本文有异议

本例使用登录页面演示,session的状态保持功能。

说明:因为http是无状态的,客户端请求一次页面后,就结束了,当再次访问时,服务器端并不知道浏览器此访问过什么。所以这样就需要状态保持功能,状态保存有两种方式:session和cookie都能实现状态保持。

状态保持

  • http协议是无状态的:每次请求都是一次新的请求,不会记得之前通信的状态
  • 客户端与服务器端的一次通信,就是一次会话
  • 实现状态保持的方式:在客户端或服务器端存储与会话有关的数据
  • 存储方式包括cookie、session,会话一般指session对象
  • 使用cookie,所有数据存储在客户端,注意不要存储敏感信息
  • 推荐使用sesison方式,所有数据存储在服务器端,在客户端cookie中存储session_id
  • 状态保持的目的是在一段时间内跟踪请求者的状态,可以实现跨页面访问当前请求者的数据
  • 注意:不同的请求者之间不会共享这个数据,与请求者一一对应

启动web服务:

  1. cd py3/django-test1/test3
  2. python manage.py runserver 192.168.255.70:8000

修改数据库类型:

  1. vim test3/settings.py
  2.  
  3. DATABASES = {
  4. 'default': {
  5. 'ENGINE': 'django.db.backends.mysql',
  6. 'NAME': 'test2',
  7. 'USER':'root',
  8. 'PASSWORD':'root',
  9. 'HOST':'192.168.255.70',
  10. 'PORT':'3306',
  11. }
  12. }

如果该数据库test2此前没有创建过表,需要进行2步迁移:

第一步:生成迁移:

  1. python manage.py makemigrations

第二步:执行迁移:

  1. python manage.py migrate

本次使用的test2表,此前进行过迁移了,因此这2步迁移省略了。

编辑视图函数:

  1. cd py3/django-test1/test3
  2. vim booktest/views.py
  3.  
  4. from django.shortcuts import render, redirect
  5. from django.http import HttpResponse, HttpResponseRedirect
  6.  
  7. def session1(request):
  8. # uname = request.session['myname']
  9. uname = request.session.get('myname','no login')
  10. context = {"username":uname}
  11. return render(request,'booktest/session1.html',context)
  12. def session2(request):
  13. return render(request,'booktest/session2.html')
  14. def session2_handle(request):
  15. uname = request.POST['uname']
  16. request.session['myname'] = uname
  17. #关闭浏览器session就过期
  18. #request.session.set_expiry(0)
  19. return redirect('/booktest/session1/')
  20. def session3(request):
  21. del request.session['myname']
  22. return redirect('/booktest/session1/')

编辑应用url路由:

  1. vim booktest/urls.py
  2.  
  3.  
  4. from django.conf.urls import url
  5. from . import views
  6. urlpatterns = [
  7. url(r'^session1/$',views.session1),
  8. url(r'^session2/$',views.session2),
  9. url(r'^session2_handle/$',views.session2_handle),
  10. url(r'^session3/$',views.session3),
  11. ]

编辑html模板文件:

session1.html文件:

  1. vim templates/booktest/session1.html
  2.  
  3. <!DOCTYPE html>
  4. <html>
  5. <head>
  6. <title>登录</title>
  7. </head>
  8. <body>
  9. 您好:{{ username }}
  10.  
  11. <br>
  12. <a href="/booktest/session2/" rel="external nofollow" >login</a>
  13. </br>
  14. <a href="/booktest/session3/" rel="external nofollow" >exit</a>
  15. </body>
  16. </html>

session2.html文件:

  1. vim templates/booktest/session2.html
  2.  
  3. <!DOCTYPE html>
  4. <html>
  5. <head>
  6. <title>登录</title>
  7. </head>
  8. <body>
  9. <form method="post" action="/booktest/session2_handle/">
  10. <input type="text" name="uname">
  11. <input type="submit" name="login">
  12. </form>
  13. </body>
  14. </html>

浏览器访问:http://192.168.255.70:8000/booktest/session1/

点击login,填写登录信息,url变为192.168.255.70:8000/booktest/session2:

点击提交,显示登录的用户名(此处省略了,从数据库查询是否有该用户):

点击exit,退出登录,回到初始界面,url地址变为192.168.255.70:8000/booktest/session1:

完成简单的session保持功能,后续再添加判断从数据库中查询是否存在用户,且密码是否正确,再显示登录成功。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持w3xue。

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号