Django 密码修改后会话失效的解决方案
技术百科
霞舞
发布时间:2026-01-01
浏览: 次 django 默认在用户密码变更时使旧会话失效,导致用户被登出;需调用 `update_session_auth_hash()` 保持登录状态。
在 Django 中,当用户密码被修改(尤其是通过 user.set_password() 或直接更新 user.password 字段)后,框架会自动使所有基于旧密码哈希生成的会话失效——这是出于安全考虑的默认行为:防止密码泄露后攻击者继续利用已存在的会话令牌。因此,即使用户仍在浏览页面,request.user 也会变为匿名(is_anonymous=True),看似“意外登出”。
你当前的视图中存在两个关键问题:
- 未调用 update_session_auth_hash():这是解决该问题的核心。它会重新生成并更新当前会话的认证哈希,使其与新密码匹配;
- 手动赋值 user.password = make_password(...) 不推荐:应优先使用 user.set_password(),它不仅加密密码,还会自动处理盐值、算法升级等细节,并兼容后续的 session hash 更新。
✅ 正确做法如下(已修复):
from django.contrib.auth import update_session_auth_hash
from django.contrib import messages
def psswdReset(request):
if request.method == 'POST':
new_psswd = request.POST.get('new_psswd')
psswd = request.POST.get('psswd')
# 验证原密码(注意:check_password 接收明文 vs 哈希)
if check_password(psswd, request.user.password):
user = request.user # 直接使用 request.user,无需重复查询
user.set_password(new_psswd) # ✅ 推荐方式:自动处理加密与兼容性
user.save()
# ✅ 关键一步:更新当前会话的认证哈希,避免登出
update_session_auth_hash(request, user)
messages.success(request, 'Password changed successfully!')
return render(request, 'User/userPsswdReset.html', {})
return render(request, 'User/userPsswdReset.html', {})⚠️ 注意事项:
- update_session_auth_hash() 必须在 user.save() 之后、响应返回之前调用;
- 它仅影响当前请求的会话,其他设备/浏览器的会话仍会失效(符合安全设计);
- 若使用 authenticate() + login() 流程(如登录页),无需手动调用此函数——login() 内部已自动处理;
- 切勿跳过原密码校验(即 check_password),否则将削弱账户安全性。
总结:Django 的会话自动失效机制是主动的安全防护,而非 bug;正确使用 update_session_auth_hash() 即可在保障安全的前提下提供无缝的密码更新体验。
# 安全防护
# 浏览器
# word
# go
# html
# session
# django
相关栏目:
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
AI推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
SEO优化<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
技术百科<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
谷歌推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
百度推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
网络营销<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
案例网站<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
精选文章<?muma echo $count; ?>
】
相关推荐
- Mac如何设置动态壁纸?(让桌面动起来)
- 如何诊断并终止卡死的 multiprocessin
- Win11怎么设置屏保时间_调整Win11屏幕保护
- Win11怎么关闭自动调节亮度 Win11禁用内容
- php错误怎么开启_display_errors与
- Win11如何设置环境变量 Win11添加和修改系
- 如何在 Python 中将 ISO 8601 时间
- Win11怎么关闭通知中心_Windows11系统
- Win10如何更改用户账户控制_Windows10
- 如何使用Golang捕获测试日志_Golang t
- Win11怎么查看wifi信号强度_检测Windo
- 使用类变量定义字符串常量时如何实现类型安全的 Li
- c++如何获取map中所有的键_C++遍历键值对提
- php转mp4怎么保留字幕_php处理带字幕视频转
- php打包exe后无法读取环境变量_变量配置方法【
- Linux如何使用Curl发送请求_Linux下A
- c# await 一个已经完成的Task会发生什么
- 怎么将XML数据可视化 D3.js加载XML
- php中::能用于接口静态方法吗_接口静态方法调用
- Win11怎么设置任务栏透明_Windows11使
- Windows如何使用BitLocker To G
- Win11怎样安装搜狗输入法_Win11安装搜狗输
- php增删改查在php8里有什么变化_新特性对cu
- 本地php环境打开php文件直接下载_浏览器解析p
- PHP 中如何在函数内持久化修改引用变量的指向
- Go语言中正确反序列化多个同级XML元素为结构体切
- c# 在ASP.NET Core中管理和取消后台任
- TestNG的testng.xml配置文件怎么写
- Win10怎么卸载爱奇艺_Win10彻底卸载爱奇艺
- Django 密码修改后会话失效的解决方案
- Win10如何优化内存使用_Win10内存优化技巧
- Python深度学习实战教程_神经网络模型构建与训
- mac怎么看硬盘大小_MAC查看磁盘存储空间与文件
- PHP接收参数值为空怎么办_判断和处理空参数方法说
- Win11怎么开启自动HDR画质_Windows1
- Win11如何开启telnet服务 Win11启用
- windows如何禁用驱动程序强制签名_windo
- 如何使用Golang搭建本地API测试环境_快速验
- 如何使用Golang table-driven f
- PHP cURL GET请求:正确设置认证与自定义
- PHP主流架构如何处理会话管理_Session与C
- Mac如何修改Hosts文件?(本地开发与屏蔽网站
- PythonPandas数据分析教程_数据清洗与处
- 如何在Mac上搭建Golang开发环境_使用Hom
- Win10如何卸载WindowsDefender_
- Win10怎样卸载DockerDesktop_Wi
- Windows 10自带杀毒软件在哪_Window
- Windows10系统怎么查看CPU温度_Win1
- 如何在 Pandas 中按元素交集合并两列字符串
- php485返回空数组怎么回事_php485数据接

user.save()
# ✅ 关键一步:更新当前会话的认证哈希,避免登出
update_session_auth_hash(request, user)
messages.success(request, 'Password changed successfully!')
return render(request, 'User/userPsswdReset.html', {})
return render(request, 'User/userPsswdReset.html', {})
QQ客服