samedi 5 novembre 2016

Laravel's 5.3 authentication not working

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