Cookie+Base64编码:一个不易察觉的坑

本文讲述了在Cookie中使用Base64编码用户姓名时遇到的问题。由于Cookie自动添加双引号和Base64编码可能包含特殊字符,导致某些用户在解码时出现错误。通过分析Cookie处理机制和Base64编码规则,找到了问题根源。解决方案是在解码前检查并去除Base64字符串首尾的双引号。
摘要由CSDN通过智能技术生成

之前做过一个项目,为了更简单的实现业务功能,我在 Cookie 中存放了用户姓名信息。

但我们知道 Cookie 中只支持 ASCII 码,而且 Cookie 本身就有其安全性的隐患,加之我保存的是姓名这种敏感信息。所以,出于编码和安全性这两点考虑,我选择了在服务端设置 Cookie 时使用 Base64 编码,之后在前端 JS 脚本中对该字符串进行 Base64 解码提取真实数据。

编码方式(该项目服务端应用基于 Django 框架开发,所以这里拿 Python 举例),借助于 base64 模块非常简单

import base64

user_name = base64.b64encode(user.name)
response.set_cookie('user_name', user_name, 36000)<
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值