2017-08-17 19 views
0

ミドルウェアを掘り起こすことにしました。ユーザーがプレユーザー(まだパスワードを変更していないユーザー)の場合はすべての要求をチェックする必要があります。変更パスワードルートのために。ミドルウェアのための私のコードは以下の通りです:メンバ関数への呼び出しgetName()nullへの呼び出し

<?php 

namespace App\Http\Middleware; 

use Closure; 

class IsPreuser 
{ 

    /** 
    * Handle an incoming request. 
    * 
    * @param \Illuminate\Http\Request $request 
    * @param \Closure $next 
    * @return mixed 
    */ 
    public function handle($request, Closure $next) 
    { 
     if (\Auth::user()->is_preuser) 
     { 
      if (\Route::getCurrentRoute()->getName() == 'profile.change_password') 
      { 
       echo 'hello'; 
      } 



      //return redirect()->route('profile.change_password'); 
     } 

     return $next($request); 
    } 
} 

私のルート名はprofile.change_passwordです。上記のコードでエラーが発生しましたCall to a member function getName() on null私は理解していません。私の目標は:profile.change_passwordルートにリダイレクトすることです。ユーザーがすでにこのルートにいる場合は除きます。

マイkernel.php:

<?php 

namespace App\Http; 

use Illuminate\Foundation\Http\Kernel as HttpKernel; 

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, 
     \Illuminate\Foundation\Http\Middleware\ValidatePostSize::class, 
     \App\Http\Middleware\TrimStrings::class, 
     \Illuminate\Foundation\Http\Middleware\ConvertEmptyStringsToNull::class, 
     \Illuminate\Session\Middleware\StartSession::class, 
     \App\Http\Middleware\IsPreuser::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\Session\Middleware\AuthenticateSession::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, 
    ]; 
} 
+0

'ルートを試してみてください:: currentRouteName()'代わり – apokryfos

+0

私は 'エコー\ルート:: currentRouteName()'何も出力を使用して、試してみました。 –

+0

このミドルウェアをコードにどのように組み込むのですか? 'Http/Middleware/Kernel.php'経由ですか?あなたの投稿にそれを含めてください。条件try ddの前に –

答えて

0

さて、それを修正しました。コメントで示唆されているように、問題は私のミドルウェアの配置かもしれません。私はそれを$middlewareGroupswebに移動し、リダイレクトで期待どおりに動作します。

<?php 

namespace App\Http\Middleware; 

use Closure; 

class IsPreuser 
{ 

    /** 
    * Handle an incoming request. 
    * 
    * @param \Illuminate\Http\Request $request 
    * @param \Closure $next 
    * @return mixed 
    */ 
    public function handle($request, Closure $next) 
    { 
     if (\Auth::check()) 
     { 
      if (\Auth::user()->is_preuser) 
      { 
       if (! $request->routeIs('profile.change_password') 
        && ! $request->routeIs('profile.change_password_process') 
        && ! $request->routeIs('logout')) 
       { 
        return redirect()->route('profile.change_password'); 
       } 
      } 
     } 


     return $next($request); 
    } 
} 
関連する問題