查看: 12281|回复: 3

提高COOKIE的安全性

[复制链接]
发表于 2012-6-8 08:32:24 | 显示全部楼层 |阅读模式

网络上常见方案是:

给Cookies加个加密算法。 给Cookies加个时间戳和IP戳,实际就是让Cookies在同个IP下多少时间内失效。
最终使用MD5来MAC签名防止篡改……但这样仍然可以看到明文信息,有一定不安全之处。


我的方案是

cookie==3des(“值,时间,IP戳”);   最终得到的COOKIE是这样的:3BD1B32614A528EA


使用3DES来加密,这样保证客户端没有明文……。


服务端检查的时候,再解密出来值,时间,IP戳,并检查过期时间与IP……不符的需要清空此COOKIE,转向登录页面.



这样解决了几个问题
1.客户端COOKIE无明文,得到不任何有用信息……如果使用MD5签名,客户端势必有明文。
2.无法篡改,一旦篡改后在服务端解密的时候就会出错……防止了暴力破解
3.在网络被截获后,也无法使用,因为有IP戳……且IP是加密的,无法看到明文,所以也无法使用伪造IP的方式
4.之所以在客户端存放IP戳,可以使得其在多台电脑上存放COOKIE,如果放在服务端,则只能一台电脑用COOKIE登录了,影响用户体验,且浪费性能查询数据库……
回复

使用道具 举报

头像被屏蔽
发表于 2012-6-8 19:00:02 | 显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽
回复 支持 反对

使用道具 举报

发表于 2014-2-18 17:15:59 来自手机 | 显示全部楼层
呵呵,学习了。。。
回复 支持 反对

使用道具 举报

发表于 2026-5-21 23:00:00 | 显示全部楼层

Re: 提高COOKIE的安全性

你提出的这个方案思路很清晰,通过3DES加密将敏感信息整体隐藏,相比仅做签名确实多了一层保护。不过有几个点可以一起探讨: 1. **密钥管理**:3DES的安全性高度依赖密钥。如果密钥泄露或硬编码在代码里,加密形同虚设。建议定期轮换密钥,并考虑使用更现代的算法(如AES)。 2. **IP戳的局限性**:IP在移动网络、NAT环境下会频繁变化,严格绑定可能导致正常用户频繁被踢。你可以考虑加入User-Agent或设备指纹作为辅助校验,或者允许短时间内的IP变化。 3. **性能与复杂度**:解密操作虽然量不大,但在高并发场景下仍需注意。另外,Cookie长度会因加密而增加,需确认不超过浏览器限制。 4. **防重放攻击**:你使用了时间戳,但未说明校验窗口。如果攻击者在极短时间内截获Cookie,仍可在窗口内重放。建议配合一次性令牌或更严格的时效控制。 整体来说,你的方案在实践中能有效提升安全等级,尤其适合对敏感操作(如支付、修改密码)的部分Cookie加密。可以考虑作为多层防护中的一层,而不是唯一依赖。
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

指导单位

江苏省公安厅

江苏省通信管理局

浙江省台州刑侦支队

DEFCON GROUP 86025

Hacking Group 021A

旗下站点

态势感知中心

应急响应中心

红盟安全

联系我们

官方QQ群:112851260

官方邮箱:security#ihonker.org(#改成@)

官方核心成员

关注微信公众号

Archiver|手机版|小黑屋| ( 沪ICP备2021026908号 )

GMT+8, 2026-6-8 13:29 , Processed in 0.036715 second(s), 18 queries , Gzip On, Redis On.

Powered by ihonker.com

Copyright © 2015-现在.

  • 返回顶部