in my Laravel 5.3 authentication, I'm using a middleware to verify if the user is logged in to access some page...
The problem I'm facing is that que middleware ALWAYS redirect to the login page, even when I just did log in...
My routes:
Route::get('/', 'ProdutoController@lista');
Route::get('/produtos', 'ProdutoController@lista');
Route::get('/produtos/mostra/{id}', 'ProdutoController@mostra');
Route::get('/produtos/novo', 'ProdutoController@novo');
Route::post('/produtos/adiciona', 'ProdutoController@adiciona');
Route::get('produtos/lista-json', 'ProdutoController@listaJSON');
Route::get('/produtos/remove/{id}', 'ProdutoController@remove');
Auth::routes();
Route::get('/home', 'HomeController@index');
Route::get('/login', 'LoginController@form');
Route::post('/login', 'LoginController@login');
My LoginController
class LoginController extends Controller
{
public function form () {
return view('form_login');
}
public function login () {
// Credenciais (email e senha)
$credenciais = Request::only('email', 'password');
// Login
if (Auth::attempt($credenciais)) { // caso as credenciais sejam aceitas, retorna true
return 'Usuário ' . Auth::user()->name . ' logado com sucesso';
}
else {
return 'Usuário não existe';
}
}
}
My ProdutoController
class ProdutoController extends Controller
{
public function __construct()
{
$this->middleware('Autorizador');
}
public function lista()
{
$produtos = Produto::all();
return view('produto/listagem')->with('produtos', $produtos);
}
}
My Kernel:
class Kernel extends HttpKernel
{
/**
* The application's global HTTP middleware stack.
*
* These middleware are run during every request to your application.
*
* @var array
*/
protected $middleware = [
\Illuminate\Foundation\Http\Middleware\CheckForMaintenanceMode::class,
\App\Http\Middleware\Autorizador::class,
];
/**
* The application's route middleware groups.
*
* @var array
*/
protected $middlewareGroups = [
'web' => [
\App\Http\Middleware\EncryptCookies::class,
\Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class,
\Illuminate\Session\Middleware\StartSession::class,
\Illuminate\View\Middleware\ShareErrorsFromSession::class,
\App\Http\Middleware\VerifyCsrfToken::class,
\Illuminate\Routing\Middleware\SubstituteBindings::class,
],
'api' => [
'throttle:60,1',
'bindings',
],
];
/**
* The application's route middleware.
*
* These middleware may be assigned to groups or used individually.
*
* @var array
*/
protected $routeMiddleware = [
'auth' => \Illuminate\Auth\Middleware\Authenticate::class,
'auth.basic' => \Illuminate\Auth\Middleware\AuthenticateWithBasicAuth::class,
'bindings' => \Illuminate\Routing\Middleware\SubstituteBindings::class,
'can' => \Illuminate\Auth\Middleware\Authorize::class,
'guest' => \App\Http\Middleware\RedirectIfAuthenticated::class,
'throttle' => \Illuminate\Routing\Middleware\ThrottleRequests::class,
];
}
My middleware:
class Autorizador
{
/**
* Handle an incoming request.
*
* @param \Illuminate\Http\Request $request
* @param \Closure $next
* @return mixed
*/
public function handle($request, Closure $next) // next é o código que será executado em seguida
{
if (!$request->is('login') && Auth::guest()) {
return redirect('/login');
}
return $next($request);
}
}
When I log in, I receive the message telling me that the log in was successfull and infoming me the name of the logged user, but then, when I try to access the list of my products, I am redirected to the login form again...
Any suggestions?
via Chebli Mohamed
Aucun commentaire:
Enregistrer un commentaire