PHP
보안 기억 장치 나
수색…
소개
내가이 게시물을 찾을 때까지이 주제를 검색 해왔다. https://stackoverflow.com/a/17266448/4535386 from ircmaxell, 나는 더 많은 노출을 받아야한다고 생각한다.
"Keep Me Logged In"- 최선의 접근 방식
세 부분으로 쿠키를 저장하십시오.
function onLogin($user) {
$token = GenerateRandomToken(); // generate a token, should be 128 - 256 bit
storeTokenForUser($user, $token);
$cookie = $user . ':' . $token;
$mac = hash_hmac('sha256', $cookie, SECRET_KEY);
$cookie .= ':' . $mac;
setcookie('rememberme', $cookie);
}
그런 다음 유효성을 검사합니다.
function rememberMe() {
$cookie = isset($_COOKIE['rememberme']) ? $_COOKIE['rememberme'] : '';
if ($cookie) {
list ($user, $token, $mac) = explode(':', $cookie);
if (!hash_equals(hash_hmac('sha256', $user . ':' . $token, SECRET_KEY), $mac)) {
return false;
}
$usertoken = fetchTokenByUserName($user);
if (hash_equals($usertoken, $token)) {
logUserIn($user);
}
}
}
Modified text is an extract of the original Stack Overflow Documentation
아래 라이선스 CC BY-SA 3.0
와 제휴하지 않음 Stack Overflow