有没有办法在laravel的不同数据库中对用户进行身份验证?

时间:2019-04-23 17:33:13

标签: laravel

我正在实现对不同数据库的访问,但是当使用中间件('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",
            ...

有人知道怎么做,或者我做错了什么

1 个答案:

答案 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