如何在我的包中使用laravel 6的自定义保护进行授权?

xnifntxz  于 2023-04-22  发布在  其他
关注(0)|答案(5)|浏览(144)

我尝试通过laravel包使用admins表进行身份验证。在项目目录中,我将admin guard添加到config/auth.php

'providers' => [
        'users' => [
            'driver' => 'eloquent',
            'model' => App\User::class,
        ],

        'admins' => [
            'driver' => 'eloquent',
            'model' => App\Admin::class,
        ],

        // 'users' => [
        //     'driver' => 'database',
        //     'table' => 'users',
        // ],
    ],

而在守卫阵列中

'guards' => [
        'web' => [
            'driver' => 'session',
            'provider' => 'users',
        ],

        'api' => [
            'driver' => 'token',
            'provider' => 'users',
            'hash' => false,
        ],

        'admin' => [
            'driver' => 'session',
            'provider' => 'admins',
        ],
    ],

以下是我的登录控制器内的pakakge

class LoginController extends Controller
{

   use AuthenticatesUsers;
   protected $redirectTo = '/admin/dashboard';
   protected function redirectTo()
   {
         return '/admin/dashboard';
   }

   public function __construct()
   {
       $this->middleware('guest')->except('logout');
   }
   public function login(Request $request)
   {   
       if(Auth::guard('admin')->attempt($request->only('email','password'), true)){
           return redirect()
               ->intended(route('dashboard'))
               ->with('status','You are Logged in as Admin!');
       }
   }

}

下面是我的 Jmeter 板控制器

class DashboardController extends Controller
{
    public function __construct()
    {
        /* dd(Auth::check()); */ //return false : just want to show you

          $this->middleware('auth:admin');
    }

    public function index()
    {
        return view('xyz::dashboard');
    }

}

在我的Admin.php模型中有以下脚本

namespace App;

class Admin extends \ABC\xyz\App\Models\Admin
{

}

即扩展包模型

namespace ABC\xyz\App\Models;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Foundation\Auth\User as Authenticatable;
class Admin extends Authenticatable
{

    protected $table = 'admins';
}

下面是我的包的路线

$namespace = 'ABC\Xyz\App\Http\Controllers';
    Route::group([    
    'namespace' => $namespace,
    'middleware' => ['web'], 
    'prefix' => 'admin'
], function () {
    Route::get('login', function(){
        return view('xyz::auth.login');
    })->name('login');

    Route::post('/login', 'Auth\LoginController@login')->name('customLogin');
});

Route::group(['namespace' => $namespace,'prefix' => 'admin',  'middleware' => ['auth']  ], function () {
    Route::get('dashboard', 'DashboardController@index')->name('dashboard');
});

当我尝试登录时,在提交有效的详细信息后,它没有将我重定向到 Jmeter 板,什么也没有发生。此外,当我尝试强行打开/ Jmeter 板时,它会将我带到登录页面。
同样在登录尝试后,当我尝试Auth::check()时,它返回true,但同样的事情在dashboardController.php构造函数中返回false。以同样的方式,Auth::guard('admin')->user()返回用户的信息,而在dashboardController.php上返回null。我不知道我错过了什么和哪里。
我想请你给我一些指导。我会很感激的。
谢谢你

d8tt03nd

d8tt03nd1#

当你定义一个带前缀的路由时,路由名将像prefix.name,url将像prefix/url

Route::group([    
        'namespace' => $namespace,
        'middleware' => ['web'], 
        'prefix' => 'admin'
    ], function () {
        Route::get('login', function(){
            return view('xyz::auth.login');
        })->name('login');

        Route::post('login', 'Auth\LoginController@login')->name('tryForLogin');
});

Route::group(['namespace' => $namespace,'prefix' => 'admin','middleware' => 'auth'], function () {
    Route::get('dashboard', function(){
        return view('xyz::dashboard');
    })->name('dashboard');
});

所有的组都以“admin”为前缀,但也有一些路由或页面可以在登录时访问。

dsf9zpds

dsf9zpds2#

prefix是用于定义路由端点前缀的选项。您正在查找as选项。

// gives you routes:
// GET /admin/login named "admin.login" with middleware "web"
// POST /admin/login named "admin.tryForLogin" with middleware "web"
Route::group([    
        'namespace' => $namespace,
        'middleware' => ['web'], 
        'prefix' => 'admin',
        'as' => 'admin.'
    ], function () {
        Route::get('login', function() {
            return view('xyz::auth.login');
        })
        ->name('login');

        Route::post('login', 'Auth\LoginController@login')->name('tryForLogin');
    }
);

// gives you routes:
// GET /admin/dashboard named "admin.dashboard" with middleware "auth"
Route::middleware(['auth'])->group(function () {
    Route::get('/admin/dashboard', function(){
        return view('xyz::dashboard');
    })
    ->name('admin.dashboard');
});

代码更改后运行php artisan optimize:clear

oknrviil

oknrviil3#

guest中间件(\App\Http\Middleware\RedirectIfAuthenticated)负责重定向经过身份验证的用户。
当使用中间件时,您必须将身份验证保护传递给它,以便像这样使用:
guest:guard
示例:在LoginController构造函数中,使用
$this->middleware('guest:admin')->except('logout');
而不是$this->middleware('guest')->except('logout');

laik7k3q

laik7k3q4#

使用auth('admin')->user()在您的 Jmeter 板控制器.(返回认证管理员)

lyr7nygr

lyr7nygr5#

管理模型类需要扩展用户模型类。这样,管理模型类将继承可验证类。
Authenticable类负责身份验证。

相关问题