婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > laravel實現簡單用戶權限的示例代碼

laravel實現簡單用戶權限的示例代碼

熱門標簽:廣東廣州在怎么申請400電話 電銷機器人問門薩維品牌my 開發地圖標注類網站 外呼系統能給企業帶來哪些好處 咸寧銷售電銷機器人系統 百度地圖怎樣標注圖標 余姚電話機器人 百度地圖標注偏差 400電話蘭州申請請

關于權限管理的思考

最近用laravel設計后臺,后臺需要有個權限管理。權限管理實質上分為兩個部分,首先是認證,然后是權限。認證部分非常好做,就是管理員登錄,記錄session。這個laravel中也有自帶Auth來實現這個。最麻煩就是權限認證。

權限認證本質上就是誰有權限管理什么東西。這里有兩個方面的維度,誰,就是用戶維度,在用戶維度,權限管理的粒度可以是用戶一個人,也可以是將用戶分組,如果將用戶分組,則涉及到的邏輯是一個用戶可以在多個組里面嗎?在另外一方面,管理什么東西,這個東西是物的維度,一個頁面是一個東西,一個頁面上的一個元素也是一個東西,或者往大了說,一個功能是一個東西。所以做權限管理最重要的是確認這兩個維度的粒度。這個已經不是技術的事情了,這個是需要需求討論的了。

基于上面的思考,我這次想做的權限管理,在用戶維度,是基于個人的。就是每個人的權限不一樣。在東西的維度,我設置路由為最小的單位,即可以為單個路由設置權限管理。

下面的思考就是使用什么來標記權限,可以使用位,也可以使用字符,也可以使用整型。后來我選擇了字符,基于兩點考慮:1 字符淺顯易懂,在數據庫中查找也比較方便 2 我沒有按照某個權限查找有這個權限的人的需求,即沒有反查需求,使用位,整型等都意義不大。

接下來考慮如何和laravel結合,既然要為每個路由設置訪問權限,那么我當然希望能在laravel的route.php路由管理中配置。最好就是在Route::get的時候有個參數能設置permission。這樣做的好處是權限設置簡易了。在決定路由的時候,就順手寫了權限控制。壞處呢,也很明顯,laravel路由的三種方式只能寫一種了。就是Route::(method)這樣的方式了。

基本決定好了就開干。

路由設計

基本的路由是這樣的

Route::post('/admin/validate', ['uses' => 'AdminController@postValidate', 'permissions'=>['admin.validate', 'admin.index']]);

這里在基本的制定路由action之后設置了一個permissions的屬性,這個屬性設計成數組,因為比如一個post請求,它可能在某個頁面會觸發,也可能在另外一個頁面觸發,那么這個post請求就需要同時擁有兩個頁面路由的權限。

這里使用admin.validate的權限控制,這樣,可以將權限分組,admin都是關于admin相關的分組,在數據庫中,我就會存儲一個二維數組,[admin] => ['validate', 'index']; 存儲成二維數組而不是一維的好處呢,一般后臺展示是有兩個維度的,一個是頭部的tab欄,一個是左邊的nav欄,就是說這個二維的數組和后臺的tab,nav欄是一一對應的。

中間件設計

好了,下面我們就掛上中間件,并且設置所有的路由都走這個中間件

?php namespace App\Http\Middleware;

use Illuminate\Support\Facades\Session;
use Closure;

class Permission {

  /**
   * Handle an incoming request.
   *
   * @param \Illuminate\Http\Request $request
   * @param \Closure $next
   * @return mixed
   */
  public function handle($request, Closure $next)
  {
    $permits = $this->getPermission($request);

    $admin = \App\Http\Middleware\Authenticate::getAuthUser();

    // 只要有一個有權限,就可以進入這個請求
    foreach ($permits as $permit) {
      if ($permit == '*') {
        return $next($request);
      }
      if ($admin->hasPermission($permit)) {
        return $next($request);
      }
    }

    echo "沒有權限,請聯系管理員";exit;
  }

  // 獲取當前路由需要的權限
  public function getPermission($request)
  {
    $actions = $request->route()->getAction();
    if (empty($actions['permissions'])) {
      echo "路由沒有設置權限";exit;
    }
    return $actions['permissions'];
  }
}

這里最關鍵的就getPermission函數,從$request->route()->getAction()來獲取出這個路由的action定義,然后從其中的permissions字段中獲取route.php中定義的路由權限。

然后上面的middleware有個admin−>hasPermission(permit); 這個就涉及到model的設計。

model設計

?php namespace App\Models\Admin;

use App\Models\Model as BaseModel;

class Admin extends BaseModel {

  protected $table = 'admin';

  // 判斷是否有某個權限
  public function hasPermission($permission)
  {
    $permission_db = $this->permissions;
    if(in_array($permission, $permission_db)) {
      return true;
    }

    return false;
  }

  // permission 是一個二維數組
  public function getPermissionsAttribute($value)
  {
    if (empty($value)) {
      return [];
    }
    $data = json_decode($value, true);
    $ret = [];
    foreach ($data as $key => $value) {
      $ret[] = $key;
      foreach ($value as $value2) {
        $ret[] = "{$key}.{$value2}";
      }
    }
    return array_unique($ret);
  }

  // 全局設置permission
  public function setPermissionsAttribute($value)
  {
    $ret = [];
    foreach ($value as $item) {
      $keys = explode('.', $item);
      if (count($keys) != 2) {
        continue;
      }
      $ret[$keys[0]][] = $keys[1];
    }

    $this->attributes['permissions'] = json_encode($ret);
  }
}

在數據庫中,我將二維數組存儲為json,利用laravel的Attribute的get和set方法,完成了數據庫中json和外界程序邏輯的連接。然后hasPermission就顯得很輕松了,直接判斷in_array就ok了。

后續

這個權限認證的邏輯就清晰了。然后如果頁面中某個tab或者nav需要對不同權限的用戶展示,只需要在view中判斷

@if ($admin->hasPermission('admin.index')) 
@endif

就可以判斷這個用戶是否可以看到這個tab了。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • 在Laravel5中正確設置文件權限的方法
  • Laravel5權限管理方法詳解
  • Laravel框架實現的rbac權限管理操作示例
  • 解決laravel中日志權限莫名變成了root的問題
  • laravel利用中間件做防非法登錄和權限控制示例
  • Laravel5.1數據庫連接、創建數據庫、創建model及創建控制器的方法
  • laravel5.1框架基礎之Blade模板繼承簡單使用方法分析
  • Laravel5.1框架注冊中間件的三種場景詳解
  • laravel5.1框架基礎之路由詳解
  • laravel5.1框架model類查詢的實現方法
  • Laravel5.1框架自帶權限控制系統 ACL用法分析

標簽:麗江 銅陵 巴彥淖爾 鷹潭 衡陽 臨沂 重慶 十堰

巨人網絡通訊聲明:本文標題《laravel實現簡單用戶權限的示例代碼》,本文關鍵詞  laravel,實現,簡單,用戶,權限,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《laravel實現簡單用戶權限的示例代碼》相關的同類信息!
  • 本頁收集關于laravel實現簡單用戶權限的示例代碼的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 孟村| 聂拉木县| 潼南县| 象州县| 廊坊市| 特克斯县| 清苑县| 三门县| 建瓯市| 盐边县| 大港区| 玉田县| 同江市| 裕民县| 梁河县| 清徐县| 屯留县| 象州县| 林口县| 赞皇县| 临夏县| 鹿邑县| 犍为县| 丘北县| 卢龙县| 天台县| 双峰县| 香河县| 浦县| 叶城县| 谷城县| 民和| 炎陵县| 和政县| 平谷区| 锡林郭勒盟| 太仆寺旗| 剑川县| 资兴市| 股票| 临泉县|