我有一个登录处理文件,尝试在其中设置cookie:
$expTime = time() + 3600;
$key = getenv("SECRET_KEY");
$token = array(
"iss" => request()->getBaseUrl(),
"sub" => [$user['id']],
"exp" => $expTime,
"iat" => time(),
"nbf" => time(),
"is_admin" => $user['role_id'] == 1
);
$jwt = JWT::encode($token, $key);
$accessToken = new Cookie('access_token', $jwt, $expTime, '/', getenv("COOKIE_DOMAIN"));
redirect('/', ['cookies' => [$accessToken]]);我使用Firebase/JWT来包含一个JWT作为cookie值。从我的.ENV文件中拉入SECRET_KEY和COOKIE_DOMAIN。
然后我调用我的redirect()
function redirect($path, $extra = []) {
$response = new Response(
null,
Response::HTTP_FOUND,
array('location' => $path)
);
if (key_exists('cookies', $extra)) {
foreach ($extra['cookies'] as $cookie) {
$response->headers->setCookie($cookie);
}
}
$response->send();
}然后测试是否在我的索引文件中设置了cookie:
if (request()->cookies->has('access_token')) {
echo "Logged in";
} else echo "No cookie :(";我的问题是我的测试返回"No cookie :(“。
任何帮助都将不胜感激。
如果你愿意,你可以在GutHub上分支它:jpradcliffe/user-authentication
https://stackoverflow.com/questions/44467526
复制相似问题