douduikai0562 2013-12-29 22:40
浏览 82
已采纳

Laravel:使用一个规则过滤多个控制器的最简单方法?

I have a users table with a field called 'role', 0 - regular users, 1 - admin.

I have multiple controllers that only the admin uses. What is the easiest way to only allow users with a role of 1 to use them? I will have all these controllers in a folder called 'admin'.

Currently I have an if test in my routes.php file like this

if(Auth::user()->role == 1) {

    Route::resource('someRes', 'someResController');

}

But I have come to realize this is the wrong way to do it.

  • 写回答

2条回答 默认 最新

  • douou6807 2013-12-29 23:43
    关注

    As mentioned, use route groups, allows you to group routes and filter:

    Route::group(array('before' => 'checkUser'), function()
    {
       Route::resource('someRes', 'someResController');
       Route::resource('anotherRes', 'anotherResController');
    });
    

    Then in your filters:

    Route::filter('checkUser', function()
    {
        if(Auth::user()->role !== 1)
        {
            return Redirect::route('loginRoute')->with('message', 'Authorization required');
        }
    });
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 宇视监控服务器无法登录
  • ¥15 PADS Logic 原理图
  • ¥15 PADS Logic 图标
  • ¥15 电脑和power bi环境都是英文如何将日期层次结构转换成英文
  • ¥15 DruidDataSource一直closing
  • ¥20 气象站点数据求取中~
  • ¥15 如何获取APP内弹出的网址链接
  • ¥15 wifi 图标不见了 不知道怎么办 上不了网 变成小地球了
  • ¥50 STM32单片机传感器读取错误
  • ¥50 power BI 从Mysql服务器导入数据,但连接进去后显示表无数据