public static function login($username,$password)
{
$userInfo = User::where('username',$username)->first();
if ($userInfo) {
if ($userInfo->password == md5($password)) {
$userToken = base64_encode($username.$password);
$userTokenKey = "USER_TOKEN_STORE_KEY".$userToken;
$tokenInfo = [
'user_id' => $userInfo->id,
'username' => $userInfo->username
];
Redis::setex($userTokenKey, 3600*2, json_encode($tokenInfo, JSON_UNESCAPED_UNICODE));
return ['code'=>0,'msg'=>'登录成功']];
} else {
return ['code'=>1,'msg'=>'登录失败,用户名或密码错误'];
}
} else {
return ['code'=>1,'msg'=>'登录失败,用户名或密码错误'];
}
}
public function handle($request, Closure $next)
{
$tokenString = (string)$request->header("access-token");
if ($tokenString === "") {
return response()->json(['code'=>1,'msg'=>'token不能为空']);
}
$userTokenKey = RedisKey::USER_TOKEN_KEY.$tokenString;
if (Redis::exists($userTokenKey)) {
$tokenInfo = json_decode(Redis::get($userTokenKey), true);
} else {
return response()->json(['code'=>1,'msg'=>'token失效']);
}
if (!empty($tokenInfo)) {
$request->attributes->add([
"user_id" => $tokenInfo['user_id'],
"username" => $tokenInfo['username']
]);
$arr = $this->preResponse($request->all());
$request->merge($arr);
return $next($request);
} else {
return response()->json(['code'=>1,'msg'=>'token失效']);
}
}