laravel 中的中间件无法正常工作

Middleware in laravel does not works properly

我正在尝试像这样在我的路由上应用中间件:

Route::get('twitterlogin','TwitterController@gettwitterlogin'); 
Route::post('twitterlogin','TwitterController@posttwitterlogin');   
Route::group(['middleware'=>'auth'],function()
{
    Route::get('twitternewsfeed','TwitterController@gettwitternewsfeed');   
    Route::post('postimage','TwitterController@postimage');     
    Route::post('posttweet','TwitterController@posttweet');     
    Route::get('twitterlogout','TwitterController@gettwitterlogout');   
    Route::post('editprofilepic','TwitterController@posteditprofilepic');   
    Route::post('searchuser','TwitterController@postsearchuser');   
    Route::post('edittweet{id}','TwitterController@postedittweet');     
    Route::get('deletetweet{id}','TwitterController@getdeletetweet');   
    Route::post('editprofile','TwitterController@posteditprofile');     
    Route::get('userprofile{email}','TwitterController@getuserprofile');  
}); 

当我尝试提交我的登录表单时,它没有将我带到下一页。它再次打开登录页面....这到底是什么问题?我的认证中间件如下....

<?php

namespace App\Http\Middleware;

use Closure;
use Illuminate\Contracts\Auth\Guard;

class Authenticate
{
    /**
     * The Guard implementation.
     *
     * @var Guard
     */
    protected $auth;

/**
 * Create a new middleware instance.
 *
 * @param  Guard  $auth
 * @return void
 */
public function __construct(Guard $auth)
{
    $this->auth = $auth;
}

/**
 * Handle an incoming request.
 *
 * @param  \Illuminate\Http\Request  $request
 * @param  \Closure  $next
 * @return mixed
 */
public function handle($request, Closure $next)
{
    if ($this->auth->guest()) {
        if ($request->ajax()) {
            return response('Unauthorized.', 401);
        } else {
            return redirect()->guest('twitterlogin');
        }
    }

    return $next($request);
}
}

我假设您正在使用 Route::post('twitterlogin','TwitterController@posttwitterlogin') 路由来执行登录操作 - 请确保您使用 Laravel's Auth 正确登录用户并将用户重定向到posttwitterlogin 方法

我觉得您也可能使用不同的 table 来存储用户数据 - 在这种情况下,请确保您有 auth.php config file setup appropriately

如果您出于某种原因使用自定义身份验证机制,则需要将中间件中的 $this->auth->guest() 替换为对未登录用户进行适当的替代检查

例如:如果您在成功登录后使用 \Session::put('is_authenticated', true) 将名为 is_authenticated 的会话变量设置为 true,您将使用 [=16= 检查它] 在你的中间件中,而不是依赖 Laravel Auth 方法 if ($this->auth->guest())