TK1*_*123 3 php ip session networking
作为我正在进行的登录系统的一部分,我在每个客户端命名的唯一会话中跟踪失败的登录尝试:
if($login_failed) {
// update failed login attempts
$session_name = 'failed_attempts'.$_SERVER['REMOTE_ADDR'];
if(!isset($_SESSION[$session_name])) {
$_SESSION[$session_name] = 1;
}
else {
$_SESSION[$session_name] += 1;
}
}
Run Code Online (Sandbox Code Playgroud)
如您所见,为了确定每个会话的唯一名称,我将用户的IP地址附加到字符串"failed_login_attempts"的末尾.
如果用户达到5次失败尝试,我需要在每次后续尝试时填写验证码.
我只是担心可能会有一些网络为许多用户分配了相同的IP地址,在这种情况下,如果1个用户无法登录,他们都会开始看到验证码,即使只有1个用户需要显示验证码.
这是合理的还是永远不会有2个用户可以拥有相同的IP,例如他们可能拥有相同的前3个八位字节,但最后一个数字将是不同的,在这种情况下我不必担心.
如果有多个用户共享同一个IP的机会,那么确定我的会话名称的唯一标识符的好方法是将未登录的用户链接到会话?