我试图允许用户在 Laravel 5.4 中查看自己的个人资料。
用户策略.php
public function view(User $authUser, $user)
{
return true;
}
在 AuthServiceProvider.php 中注册策略
protected $policies = [
App\Task::class => App\Policies\TaskPolicy::class,
App\User::class => App\Policies\UserPolicy::class
];
Routes
Route::group(['middleware' => 'auth'], function() {
Route::resource('user', 'UserController');
} );
刀片模板
@can ( 'view', $user )
// yes
@else
// no
@endcan
用户控制器.php
public function profile()
{
return $this->show(Auth::user()->id);
}
public function show($id)
{
$user = User::find($id);
return view('user.show', array( 'user'=>$user,'data'=>$this->data ) );
}
返回值始终为“假”。从控制器调用策略也是如此。我哪里出错了?