PHP写登录安全之-会话固定和会话重用即session和cookie的使用

最近在给政府单位做网站后台编辑模块,被检测出会话固定和会话重用安全问题,解决如下:

解决思路:

首先在做登录是,必须要了解的是客户端的cookie和服务端的session,登录后,不仅要保存服务端的session,还要保存浏览器即客户端的cookie,检测登录时,必须session和cookie的相同key的value值相同,才可验证是否登录。

通过刚才的思路,我们有如下操作:

1、登录界面代码编写;(自己写吧,这里不麻烦写了)

2、点击登录之后的PHP代码逻辑编写;

特别注意的是,当登录用户名和密码以及验证码验证通过后,需要些如服务端session:例如

$se = md5($admin_info['id'].$admin_info['user_name'].time());
Session::set('yebao_admin', [
            'admin' => [
                'admin_id' => $admin_info['id'],
                'user_name' => $admin_info['user_name'],
            ],
            'is_login' => true,
            'auth' => $se,
        ]);

$se :用户ID+用户名+时间的MD5加密字符串,编写浏览器cookie是也要用到这个字符串

$admin_info:用户信息

然后编写浏览器cookie:例如

setcookie("auth", $se,time()+3600,"/");

记住,setcookie时,一定要注意加上第三个参数值 “ "/" ”,做到全局更换,不然浏览器认为只在当前页面设置了cookie,而不是全部页面。

有关注意事项,下图中已用红框标记:↓

至此,登录操作完成,之后的验证是否登录就好做多了。 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值