我在 laravel 5.2 中有一个自定义身份验证登录,我的自定义登录配置是
'guards' => [
'web' => [
'driver' => 'session',
'provider' => 'users',
],
'provider' => [
'driver' => 'session',
'provider' => 'providers',
],
],
我有两个身份验证 Controller ,一个是 laravel AuthController,另一个是 ProviderAuthController。我已经在我的环境中设置了 SESSION_DRIVER=database 并且还在我的数据库中创建了一个 session 表我正在从 Web 登录获取 session ,但问题是我无法在提供者登录时获取 session 。是否有任何解决方法可以在提供者登录时插入 session 。
我的应用服务商里面什么都没有
<?php
namespace App\Providers;
use Illuminate\Support\ServiceProvider;
class AppServiceProvider extends ServiceProvider
{
/**
* Bootstrap any application services.
*
* @return void
*/
public function boot()
{
//
}
/**
* Register any application services.
*
* @return void
*/
public function register()
{
//
}
}
providerAuthcontroller 的路由是 Route::group(['prefix' => 'provider'], function(){
Route::get('login', 'Auth\ProviderAuthController@showLoginForm');
Route::post('login', 'Auth\ProviderAuthController@login');
Route::get('logout', 'Auth\ProviderAuthController@logout');
// Registration Routes...
Route::get('register', 'Auth\ProviderAuthController@showRegistrationForm');
Route::post('register', 'Auth\ProviderAuthController@register');
// Password Reset Routes...
Route::get('password/reset/{token?}', 'Auth\ProviderPasswordController@showResetForm');
Route::post('password/email', 'Auth\ProviderPasswordController@sendResetLinkEmail');
Route::post('password/reset', 'Auth\ProviderPasswordController@reset');
最佳答案
它应该发生在中间件中,而不是提供者中。
Route::get('profile', function () {
// Only authenticated users may enter...
})->middleware('auth');
和
class Auth
{
public function handle(\Illuminate\Http\Request $request, Closure $next)
{
if(!$request->session()->get('authenticated'){
throw AuthException();
}
return $next($request);
}
}
同时检查 laravel lifecycle .
关于php - laravel 5.2 将登录 session 数据插入自定义身份验证的数据库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48140332/