我正在实现对不同数据库的访问,但是当使用中间件('auth:api')时,它表示我未通过身份验证,并且在登录时我得到了令牌。
这仅在数据库不是默认数据库时发生
我在laravel 5.8上
public function login(LoginRequest $request, $db)
{
Config::set("database.connections.mysql.database", $db);
if (Auth::attempt(['email' => request('email'), 'password' => request('password')])) {
$this->user = Auth::user();
$this->user->token = $this->user->createToken('ControlEscolar')->accessToken;
$status = 200;
} else {
$this->user['error'] = "Unauthorized";
$status = 401;
}
return response()->json($this->user, $status);
}
public function userData($db)
{
Config::set("database.connections.mysql.database", $db);
$user = userData::whereUserId(Auth::user()->id)
->first();
return $user;
}
在登录功能上,我得到了...
{
"id": 1,
"name": "name of user",
...
"token": "eyJ0eXAiO...CFU"
}
因此有效
但是在第二个用户数据中我得到了
{
"error": {
"message": "Unauthenticated.",
"status_code": 500,
"debug": {
"line": 67,
"file": "/Users/.../vendor/laravel/framework/src/Illuminate/Auth/Middleware/Authenticate.php",
"class": "Illuminate\\Auth\\AuthenticationException",
...
有人知道怎么做,或者我做错了什么
答案 0 :(得分:0)
我通过对路由文件进行配置设置来解决上述问题:
$api->group(['prefix' => 'auth'], function (Router $api) {
Config::set("database.connections.mysql.database", $db);
$api->post('singup', 'App\\Api\\V1\\Controllers\\SignUpController@signUp');
});
顺便说一句,我正在使用dingo Api