电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

Django cookie和session的應用場景及如何使用

瀏覽:2日期:2024-09-08 18:00:42
為什么需要使用cookie和ses sion?

HTTP協議本身是”無狀態”的,在一次請求和下一次請求之間沒有任何狀態保持,服務器無法識別來自同一用戶的連續請求。有了cookie和session,服務器就可以利用它們記錄客戶端的訪問狀態了,這樣用戶就不用在每次訪問不同頁面都需要登錄了。

什么是cookie,cookie的應用場景及缺點

cookie是一種數據存儲技術, 它是將一段文本保存在客戶端(瀏覽器或本地電腦)的一種技術,并且可以長時間的保存。當用戶首次通過客戶端訪問服務器時,web服務器會發送給客戶端的一小段信息。客戶端瀏覽器會將這段信息以cookie形式保存在本地某個目錄下的文件內。當客戶端下次再發送請求時會自動將cookie也發送到服務器端,這樣服務器端通過查驗cookie內容就知道該客戶端早訪問過了。

cookie的常見應用場景包括:

判斷用戶是否已經登錄 記錄用戶登錄信息(比如用戶名,上次登錄時間) 記錄用戶搜索關鍵詞

cookie的缺點在于其并不可靠和不安全,主要原因如下:

瀏覽器不一定會保存服務器發來的cookie,用戶可以通過設置選擇是否保存cookie。 cookie是有生命周期的(通過Expire設置),如果超過周期,cookie就會被清除。 HTTP數據通過明文發送,容易受到攻擊,因此不能在cookie中存放敏感信息(比如信用卡號,密碼等)。 cookie以文件形式存儲在客戶端,用戶可以隨意修改的。Django中如何使用cookies

設置cookies(保存數據到客戶端)

response.set_cookie(key,value,expires)

key : cookie的名稱 value : 保存的cookie的值 expires : 保存的時間,以秒為單位

例子: response.set_cookie(’username’,’John’,60*60*24)

一般在Django的視圖中先生成不含cookie的response,然后set_cookie, 最后把response返回給客戶端(瀏覽器)。

下面是3個設置cookie的例子:

例子1、不使用模板

response = HttpResponse('hello world')response.set_cookie(key,value,expires)return response

例子2、使用模板

response = render(request,’xxx.html’, context)response.set_cookie(key,value,expires)return response

例子3、重定向

response = HttpResponseRedirect(’/login/’)response.set_cookie(key,value,expires)return response

獲取cookies,獲取用戶發來請求中的cookies

request.COOKIES[’username’]request.COOKIES.get(’username’)

檢查cookies是否已經存在

request.COOKIES.has_key(’<cookie_name>’)

刪除cookies

response.delete_cookie(’username’)

下面是django中使用cookie驗證用戶是否已登錄的完整代碼。

# 如果登錄成功,設置cookiedef login(request): if request.method == ’POST’:form = LoginForm(request.POST)if form.is_valid(): username = form.cleaned_data[’username’] password = form.cleaned_data[’password’] user = User.objects.filter(username__exact=username, password__exact=password) if user:response = HttpResponseRedirect(’/index/’)# 將username寫入瀏覽器cookie,失效時間為360秒response.set_cookie(’username’, username, 3600)return response else:return HttpResponseRedirect(’/login/’) else:form = LoginForm() return render(request, ’users/login.html’, {’form’: form})# 通過cookie判斷用戶是否已登錄def index(request):#提取游覽器中的cookie,如果不為空,表示為已登錄帳號 username = request.COOKIES.get(’username’, ’’) if not username:return HttpResponseRedirect(’/login/’) return render(request, ’index.html’, {’username’: username})什么是session及session的工作原理

session又名會話,其功能與應用場景與cookie類似,用來存儲少量的數據或信息。但由于數據存儲在服務器上,而不是客戶端上,所以比cookie更安全。

Session工作的流程如下:

客戶端向服務器發送請求時,看本地是否有cookie文件。如果有,就在HTTP的請求頭(Request Headers)中,包含一行cookie信息。 服務器接收到請求后,根據cookie信息,得到sessionId,根據sessionId找到對應的session,用這個session就能判斷出用戶是否登錄等等。

使用Session的好處在于,即使用戶關閉了瀏覽器,session仍將保持到會話過期。

Django中如何使用會話session

設置session的值

request.session[’key’] = valuerequest.session.set_expiry(time):設置過期時間,0表示瀏覽器關閉則失效

獲取session的值

request.session.get(’key’,None)

刪除 session 的值

del request.session[’key’]

判斷是否在session里

’fav_color’ in request.session

獲取所有session的key和value

request.session.keys()request.session.values()request.session.items()

settings.py 有關session的設置

1、SESSION_COOKIE_AGE = 60 * 302、SESSION_EXPIRE_AT_BROWSER_CLOSE = True

下面是Django中通過使用session來判斷用戶是否已登錄的例子。

# 如果登錄成功,設置sessiondef login(request): if request.method == ’POST’:form = LoginForm(request.POST)if form.is_valid(): username = form.cleaned_data[’username’] password = form.cleaned_data[’password’] user = User.objects.filter(username__exact=username, password__exact=password) if user:# 將username寫入session,存入服務器request.session[’username’] = usernamereturn HttpResponseRedirect(’/index/’) else:return HttpResponseRedirect(’/login/’) else:form = LoginForm() return render(request, ’users/login.html’, {’form’: form})# 通過session判斷用戶是否已登錄def index(request): # 獲取session中username username = request.session.get(’username’, ’’) if not username:return HttpResponseRedirect(’/login/’) return render(request, ’index.html’, {’username’: username})

下面是通過session控制不讓用戶連續評論兩次的例子。實際應用中我們還可以通過session來控制用戶登錄時間,單位時間內連續輸錯密碼次數等等。

from django.http import HttpResponsedef post_comment(request, new_comment): if request.session.get(’has_commented’, False):return HttpResponse('You’ve already commented.') c = comments.Comment(comment=new_comment) c.save() request.session[’has_commented’] = True return HttpResponse(’Thanks for your comment!’)

以上就是Django cookie和session應用場景及如何使用的詳細內容,更多關于Django cookie和session的資料請關注好吧啦網其它相關文章!

標簽: Django
相關文章:
主站蜘蛛池模板: 超声骨密度仪-动脉硬化检测仪器-人体成分分析仪厂家/品牌/价格_南京科力悦 | 等离子空气净化器_医用空气消毒机_空气净化消毒机_中央家用新风系统厂家_利安达官网 | 水质传感器_水质监测站_雨量监测站_水文监测站-山东水境传感科技有限公司 | 气胀轴|气涨轴|安全夹头|安全卡盘|伺服纠偏系统厂家-天机传动 | 免联考国际MBA_在职MBA报考条件/科目/排名-MBA信息网 | DAIKIN电磁阀-意大利ATOS电磁阀-上海乾拓贸易有限公司 | ?水马注水围挡_塑料注水围挡_防撞桶-常州瑞轩水马注水围挡有限公司 | 头条搜索极速版下载安装免费新版,头条搜索极速版邀请码怎么填写? - 欧远全 | 螺钉式热电偶_便携式温度传感器_压簧式热电偶|无锡联泰仪表有限公司|首页 | 电动葫芦-河北悍象起重机械有限公司 | 手持气象站_便携式气象站_农业气象站_负氧离子监测站-山东万象环境 | 厌氧工作站-通用型厌氧工作站-上海胜秋科学仪器有限公司 | 涂层测厚仪_光泽度仪_uv能量计_紫外辐照计_太阳膜测试仪_透光率仪-林上科技 | 河南膏药贴牌-膏药代加工-膏药oem厂家-洛阳今世康医药科技有限公司 | 英超直播_英超免费在线高清直播_英超视频在线观看无插件-24直播网 | 路斯特伺服驱动器维修,伦茨伺服驱动器维修|万骏自动化百科 | 医学模型生产厂家-显微手术模拟训练器-仿真手术模拟训练系统-北京医教科技 | 电缆隧道在线监测-智慧配电站房-升压站在线监测-江苏久创电气科技有限公司 | ★店家乐|服装销售管理软件|服装店收银系统|内衣店鞋店进销存软件|连锁店管理软件|收银软件手机版|会员管理系统-手机版,云版,App | 工业铝型材生产厂家_铝合金型材配件批发精加工定制厂商 - 上海岐易铝业 | 单级/双级旋片式真空泵厂家,2xz旋片真空泵-浙江台州求精真空泵有限公司 | 耐磨陶瓷管道_除渣器厂家-淄博浩瀚陶瓷科技有限公司 | 中红外QCL激光器-其他连续-半导体连续激光器-筱晓光子 | 无菌实验室规划装修设计-一体化实验室承包-北京洁净净化工程建设施工-北京航天科恩实验室装备工程技术有限公司 | 网架支座@球铰支座@钢结构支座@成品支座厂家@万向滑动支座_桥兴工程橡胶有限公司 | 百度爱采购运营研究社社群-店铺托管-爱采购代运营-良言多米网络公司 | 真空冷冻干燥机_国产冻干机_冷冻干燥机_北京四环冻干 | 万濠投影仪_瑞士TRIMOS高度仪_尼康投影仪V12BDC|量子仪器 | 剪刃_纵剪机刀片_分条机刀片-南京雷德机械有限公司 | 花纹铝板,合金铝卷板,阴极铝板-济南恒诚铝业有限公司 | 法兰连接型电磁流量计-蒸汽孔板节流装置流量计-北京凯安达仪器仪表有限公司 | 蜘蛛车-高空作业平台-升降机-高空作业车租赁-臂式伸缩臂叉装车-登高车出租厂家 - 普雷斯特机械设备(北京)有限公司 | 无菌检查集菌仪,微生物限度仪器-苏州长留仪器百科 | 伶俐嫂培训学校_月嫂培训班在哪里报名学费是多少_月嫂免费政府培训中心推荐 | 对辊破碎机_四辊破碎机_双齿辊破碎机_华盛铭重工 | 山东锐智科电检测仪器有限公司_超声波测厚仪,涂层测厚仪,里氏硬度计,电火花检漏仪,地下管线探测仪 | 隧道风机_DWEX边墙风机_SDS射流风机-绍兴市上虞科瑞风机有限公司 | 3d打印服务,3d打印汽车,三维扫描,硅胶复模,手板,快速模具,深圳市精速三维打印科技有限公司 | 澳门精准正版免费大全,2025新澳门全年免费,新澳天天开奖免费资料大全最新,新澳2025今晚开奖资料,新澳马今天最快最新图库-首页-东莞市傲马网络科技有限公司 | 大流量卧式砂磨机_强力分散机_双行星双动力混合机_同心双轴搅拌机-莱州市龙跃化工机械有限公司 | 尚为传动-专业高精密蜗轮蜗杆,双导程蜗轮蜗杆,蜗轮蜗杆减速机,蜗杆减速机生产厂家 |