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

时间:2017-03-10 05:50:26

标签: laravel-5.1

我正在尝试在我的路线上应用中间件:

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);
}
}

1 个答案:

答案 0 :(得分:0)

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

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

如果您出于某种原因使用自定义身份验证机制,则需要将中间件中的posttwitterlogin替换为未登录用户的相应替代检查

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