摘要:權(quán)限設(shè)計是后臺管理很重要的一個功能,所以要好好設(shè)計。已經(jīng)有很多這方面的了,就不用我們重復(fù)造輪子了。
Start
權(quán)限設(shè)計是后臺管理很重要的一個功能,所以要好好設(shè)計。
PHP 已經(jīng)有很多這方面的packages了,就不用我們重復(fù)造輪子了。當然,如果你愿意可以從頭開始~
以前做權(quán)限認證的方式有好幾種,我說說常用的兩種吧!
每一個頁面認證當前需要的權(quán)限一次
在統(tǒng)一的地方(中間件)驗證
先上一下簡單的表結(jié)構(gòu)(只保留重要的信息)數(shù)據(jù)庫的模型 ER 圖
(ps:這個設(shè)計中,用戶不會直接擁有權(quán)限,只能通過角色繼承權(quán)限。有很多packages會提供用戶可以直接擁有權(quán)限功能)
模型關(guān)聯(lián)關(guān)系處理:
User 模型
belongsToMany(Role::class); } /**************************************** * 封裝一個方法方便使用 * 1. 需要的權(quán)限 * 2. 遍歷當期那用戶擁有的所有角色 * 3. 再通過角色判斷是否有當前需要的權(quán)限 ****************************************/ public function hasPermission($permissionName) { foreach ($this->roles as $role) { if ($role->permisssions()->where("name", $permissionName)->exists()) { return true;; } } return false; } }
Role 模型
belongsToMany(User::class); } // 角色和權(quán)限的模型關(guān)聯(lián)關(guān)系 public function permissions() { return $this->belongsToMany(Permission::class); } }
Permission 模型
belongsToMany(Role::class); } }
插入一些記錄:
######################################## # users: +-------+---------+-----------+ | id | name | password | +-----------------+-----------+ | 1 | gps | 123456 | +-----------------+-----------+ | 2 | david | 123456 | +-----------------+-----------+ ######################################## # roles: +-------+---------+ | id | name | +-----------------+ | 1 | admin | +-----------------+ ######################################## # permissions: +-------+-----------------+ | id | name | +-------------------------+ | 1 | create_product | | 2 | delete_product | +-------------------------+ ######################################## # role_user (用戶 gps 擁有 admin 角色身份) +---------+---------+ | role_id | user_id | +---------+---------+ | 1 | 1 | +------------------+ ######################################## # permission_role (角色 admin 擁有創(chuàng)建商品和刪除商品的權(quán)限) +---------+---------------+ | role_id | permission_id | +---------+---------------+ | 1 | 1 | | 1 | 2 | +-------------------------+First
第一種大概介紹一下:
user()->hasPermission("create_product")) { abort(403); } // do something return back()->with("status", "添加商品成功"); } public function destroy(Product $product) { // 判斷當前登錄的用戶是否有權(quán)限 if (! $request->user()->hasPermission("delete_product")) { abort(403); } // do something return back()->with("status", "刪除商品成功"); } }
通過上面的代碼我們可以看到,即使封裝了權(quán)限驗證的代碼,還是要在不同的方法進行驗證,而且可擴展性不高,這時候我們只需要在權(quán)限表加一個字段,就可以解決問題
1. permissions (加多一個 route 字段, 如果不在 laravel 中使用,可以加一個 url 字段匹配) +-------+------------------+------+-----+---------+----------------+ | Field | Type | Null | Key | Default | Extra | +-------+------------------+------+-----+---------+----------------+ | id | int(10) unsigned | NO | PRI | NULL | auto_increment | | name | varchar(191) | NO | | NULL | | | route | varchar(191) | NO | | NULL | | +-------+------------------+------+-----+---------+----------------+ 2. 這時候插入數(shù)據(jù)的時候,我們只要做好相關(guān)的錄入 +-------+-----------------+------------------+ | id | name | route | +-------------------------+------------------+ | 1 | create_product | products.store | | 2 | delete_product | products.destroy | +-------------------------+------------------+
添加好數(shù)據(jù)的時候,我們就不用再控制器里驗證了,我們只需要新建一個中間件。
first()) { // 當前用戶不擁有這個權(quán)限的名字 if (! auth()->user()->hasPermission($permission->name)) { return response()->view("errors.403", ["status" => "權(quán)限不足,需要:{$permission->name}權(quán)限"]); } } return $next($request); } }
如果是在 laravel 中使用,已經(jīng)有輪子了,請使用 https://github.com/spatie/laravel-permission
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/28487.html
摘要:最簡化權(quán)限管理系統(tǒng),基于開發(fā)?;陂_發(fā),唯一優(yōu)化的是用權(quán)限和路由別名綁定,這樣代碼寫好之后就可以直接使用。如果是超級管理員,即使沒有這個權(quán)限會自動賦予權(quán)限給超級管理員角色。默認管理員賬號密碼。然后正常執(zhí)行命令其他命令即可。 Any 最簡化權(quán)限管理系統(tǒng),基于 Laravel5.4 開發(fā)。由于 Laravel5.5 發(fā)布推遲,只好先寫個 Laravel5.4版本的,后面再升級上去。演示地址...
摘要:又限于層的內(nèi)容太多,我在這篇中將整理路由中間件控制器部分內(nèi)容。前者定義頁面路由,默認應(yīng)用中間件組后者定義無狀態(tài)路由,會應(yīng)用中間件組。命名路由可以為指定路由或者控制器方法命名,也可以為已命名的路由生成。 showImg(https://segmentfault.com/img/remote/1460000010882838); 上圖列出了 Laravel HTTP 層的相關(guān)知識大綱。由于...
摘要:設(shè)計判斷是否有某個權(quán)限是一個二維數(shù)組全局設(shè)置在數(shù)據(jù)庫中,我將二維數(shù)組存儲為,利用的的和方法,完成了數(shù)據(jù)庫中和外界程序邏輯的連接。 關(guān)于權(quán)限管理的思考最近用laravel設(shè)計后臺,后臺需要有個權(quán)限管理。權(quán)限管理實質(zhì)上分為兩個部分,首先是認證,然后是權(quán)限。認證部分非常好做,就是管理員登錄,記錄session。這個laravel中也有自帶Auth來實現(xiàn)這個。最麻煩就是權(quán)限認證。 權(quán)限認證本質(zhì)...
摘要:但也因為應(yīng)有盡有使得框架的性能比其他高性能框架低了些,為此給了幾個解決方案路由緩存經(jīng)有關(guān)部門研究,路由緩存可有效加快訪問速度以上。有朋友說框架最重要的東西是路由,我倒認為最重要的是框架中異于其他框架且能解決痛點的東西,如的。 showImg(https://segmentfault.com/img/remote/1460000006767764); 在程序界的遠古時期,大神們手持鍵盤敲...
摘要:杰出的數(shù)據(jù)庫遷移工具和緊密集成的單元測試支持,這些工具賦予你構(gòu)建任何應(yīng)用的能力。淺談應(yīng)公司要求,現(xiàn)在用重新搭一個框架,接觸了幾天對它也有了一定的了解。淺談支持,支持單元測試。更加嚴謹了,異常嚴謹?shù)腻e誤檢測和安全機制。 自從接觸php開始,用的就是thinkphp框架,它給我的感覺是輕量,且容易上手。后來進了一家外包公司又用了laravel框架,個人覺得laravel還是很高大上的,功能...
閱讀 1054·2021-11-15 18:11
閱讀 3177·2021-09-22 15:33
閱讀 3471·2021-09-01 11:42
閱讀 2666·2021-08-24 10:03
閱讀 3631·2021-07-29 13:50
閱讀 2934·2019-08-30 14:08
閱讀 1284·2019-08-28 17:56
閱讀 2267·2019-08-26 13:57