将页面访问限制为身份验证角色/许可的最佳方法是什么?我正在考虑使用Auth :: user()->角色进行检测,并将其放置在每个路由部分中.那么,在Laravel 4中是否有更好的方法或最佳实践呢?
谢谢.
解决方法:
您可以尝试这样的操作(使用过滤器进行角色检查)
Route::filter('role', function()
{
return Auth::user()->role;
});
然后在您的路线中,您可以使用以下(角色)过滤器
Route::get('protectedPage1', array('before'=>'role', function($role) {
if($role != 'admin') {
return Redirect::to('home');
}
}));
Route::get('protectedPage2', array('before'=>'role', function($role) {
if($role != 'admin') {
return Redirect::to('home');
}
}));
更新:
Route::filter('role', function()
{
if(Auth::user()->role != 'admin') {
return Redirect::to('home');
}
});
Route::get('protectedPage1', array('before'=>'role', function() {
// do your job
}));