当前位置: 首页 > article >正文

django入门教程之cookie和session【六】

cookie

服务器在响应头中设置cookie,发给客户端,浏览器拿到响应头后会自动保存下来这个cookie,并在同一个域名后续的请求中将cookie作为请求头传给服务端。

新建一个app: 

python manage.py startapp mycookie

代码编写

 mycookie/views.py文件:

#coding=utf8

from django.http import HttpResponse

from django.shortcuts import render

# Create your views here.


def set_cookie(request):
    response = HttpResponse('这是设置cookie')
    response.set_cookie("name", "lili", max_age=50)
    return response


def get_cookie(request):
    print(request.COOKIES)
    print(request.COOKIES.get("name"))
    return HttpResponse('这是读取cookie')


def del_cookie(request):
    response = HttpResponse('这是删除cookie')
    response.set_cookie("name", "lili", max_age=0)
    return response

 mycookie/urls.py文件:

from django.urls import path
from . import views

# app_name = 'cookie'

urlpatterns = [
    path('set/', views.set_cookie),
    path('get/', views.get_cookie),
    path('del/', views.del_cookie)
]

 根项目/urls.py文件

from django.contrib import admin
from django.urls import path, include


urlpatterns = [
    path('admin/', admin.site.urls),
    path('cookie/', include('mycookie.urls'))
]
浏览器访问

浏览器中访问:http://127.0.0.1:1992/cookie/get/

这时没有任何cookie。

 再访问:http://127.0.0.1:1992/cookie/set/

响应头中有返回set_cookie字段。 此时Application中也有了cookies值。

设置的max_age是50s,50s后cookie过期,如果访问http://127.0.0.1:1992/cookie/del/ 会立刻过期。过期后,再次访问网页,cookie字段就为空。

同一个域名下,访问其它路由地址,可以发现在cookie有效期内,请求头中会带有我们设置的cookie。

session 

代码编写

settings.py文件中,增加2个属性值。

# session存储引擎,默认是db,默认设置查询在本机python默认路径的global_settings.py文件:C:\Users\用户\AppData\Local\Programs\Python\Python311\Lib\site-packages\django\conf\global_settings.py
SESSION_ENGINE = "django.contrib.sessions.backends.file"
# 设置session文件存储目录,必须是已存在的目录
SESSION_FILE_PATH = BASE_DIR / "session_path"

以下代码中我们并未设置session的过期时间,django在global_settings.py中有默认的过期时间,14天。 还有默认存储引擎,只是这次举例改为file引擎。

代码如下: 

# views.py文件代码

def set_session(request):
    request.session['id'] = 10
    request.session['meta'] = 'V'
    return HttpResponse('这是设置session')


def get_session(request):
    print(request.session)  # <django.contrib.sessions.backends.file.SessionStore object at 0x000001DF88B1E610>
    print(request.session.get("id"))  # 10
    print(request.session.items())  # dict_items([('id', 10), ('meta', 'V')])
    print(request.session.get_session_cookie_age())   # 1209600s == 14天
    return HttpResponse('这是读取session')


def del_session(request):
    # 注意重复删除会报错
    # print(request.session.pop('id'))
    # print(request.session.items())
    request.session.clear()
    print(request.session.items())  # dict_items([])
    return HttpResponse('这是删除session')



# urls.py文件代码
from django.urls import path
from . import views

urlpatterns = [
    path('set/', views.set_cookie),
    path('get/', views.get_cookie),
    path('del/', views.del_cookie),
    path('set_s/', views.set_session),
    path('get_s/', views.get_session),
    path('del_s/', views.del_session)
]
浏览器访问

1、访问set_s时,响应头中返回了set-cookie,同时设置的session_path目录下生成了sessionid文件。

 2、访问get_s时,会发现请求头的cookie字段加上了sessionid。

3、访问del_s时,会将request.session里的字段清空,注意这里只是清空字段值,并不是删除session。不论是cookie还是session,一旦返回给浏览器,就由浏览器控制是否删除,要么到过期时间自动删除,要么通过浏览器设置中的清空浏览记录来删除。


http://www.kler.cn/a/610276.html

相关文章:

  • Pyecharts入门之绘制地图数据
  • 云端存储新纪元:SAN架构驱动的智能网盘解决方案
  • 高维小样本数据的在线流特征选择
  • LangChain开发(二)LangChain提示词模板Template使用
  • LeetCode Hot 100 - 矩阵 | 73.矩阵置零、54.螺旋矩阵、48.旋转图像、240.搜索二维矩阵II
  • STM32F103_LL库+寄存器学习笔记03 - GPIO设置输入模式,并轮询GPIO的电平状态
  • Day15 -实例 端口扫描工具 WAF识别工具的使用
  • 推荐一个可以自定义github主页的网站
  • WinSCP使用教程:(SFTP、SCP、FTP 和 WebDAV)
  • 【深度学习】扩散模型(Diffusion Model)详解:原理、应用与当前进展
  • 阿波罗Apollo相关配置
  • 计算机视觉3——模板匹配与拟合
  • 如何在 HTML 中嵌入外部字体,有哪些注意事项?
  • Java EE(12)——初始网络
  • 《索引江湖:B树索引与哈希索引的风云对决》
  • Rust从入门到精通之进阶篇:14.并发编程
  • 18502 字符串哈希匹配字符串
  • CF254B Jury Size
  • 备赛蓝桥杯之第十六届模拟赛2期职业院校组第六题:菜谱教程
  • ngx_http_core_root