前後端分離模式下的許可權設計方案

来源:https://www.cnblogs.com/javazhiyin/archive/2019/08/13/11344195.html
-Advertisement-
Play Games

作者:_liuxx cnblogs.com/liuyh/p/8027833.html 前後端分離模式下,所有的交互場景都變成了數據,傳統業務系統中的許可權控制方案在前端已經不再適用,因此引發了我對許可權的重新思考與設計。對於非前後端分離模式下的許可權思考,看這裡:通用數據許可權的思考與設計 許可權控制到底控制 ...


作者:_liuxx

cnblogs.com/liuyh/p/8027833.html

前後端分離模式下,所有的交互場景都變成了數據,傳統業務系統中的許可權控制方案在前端已經不再適用,因此引發了我對許可權的重新思考與設計。對於非前後端分離模式下的許可權思考,看這裡:通用數據許可權的思考與設計

許可權控制到底控制的是什麼?

在理解許可權控制之前,需要明白兩個概念:資源和許可權。什麼是資源,對於一個系統來說,系統內部的所有信息都可以理解為這個系統的資源。頁面是資源、數據是資源、按鈕是資源、圖片是資源、甚至頁面上一條分割線也可理解為是這個系統的資源。

而許可權就是訪問某個資源所需要的標識。無論系統的許可權如何設計,在用戶登錄時,都可以計算得出用戶所擁有的許可權標識集合,也就確定了該用戶能訪問哪些系統資源,這就是我理解的許可權控制的本質。於是我們可以得出:許可權控制是控制登錄用戶對於系統資源的訪問。

前後端分離模式下,前後端在許可權控制中各自的職責是什麼?

在弄清前後端在許可權控制中各自的職責是什麼之前,需要理解前後端各自在系統中的職責。這個還是很好理解:

  • 服務端:提供數據介面。

  • 前端:路由控制、頁面渲染。

由於前端負責與用戶交互,用戶所能操作的資源入口都是由前端進行控制,那麼前端的許可權控制就包括:

前端路由的許可權控制,過濾非法請求,用戶只能訪問許可權範圍內的頁面資源。
頁面內組件的許可權控制,根據用戶的許可權控制頁面組件的渲染。包括各種按鈕、表格、分割線等。

隨著前端組件化的快速發展,用戶所看到的一切均可理解為組件,頁面是個大組件,其內部由各個小組件拼湊而來,那麼前端許可權控制最終落地到對組件的許可權控制。於是腦補了出了最優雅的許可權組件使用方式:

<組件 permissionName='xxx' />

前端可以渲染出用戶許可權範圍內的各種系統資源,但是不能保證數據介面的安全性,某些比較喜歡折騰的用戶完全可以越過前端的頁面訪問我們系統的數據介面,那麼服務端的許可權控制最終落地到對介面的許可權驗證。

實現思路

引上文,系統的一切資源均可進行許可權控制,實際上也可以做到,但在我們實際的操作過程中,往往不需要細化到分割線那種程度。這裡以按鈕級許可權控製為例做實現說明,如果有更細粒度的許可權需求,此思路依然可行。

前端路由許可權控制。用戶登錄時拿到用戶擁有的許可權標識集合,在前端存儲。路由變化時,進行許可權判斷,通過則渲染對應頁面組件,否則渲染403組件。示例代碼:

let hasPermission = permission.check(current.permissionName);

<div className={styles.content}>
    {hasPermission ? children : <Exception type={403}/>}
</div>

封裝bird-button許可權按鈕組件,傳入按鈕所需許可權名,內部進行許可權判斷,通過則渲染按鈕。

<BirdButton permissionName={'sys'} type='primary'>測試按鈕</BirdButton>

服務端。服務端許可權驗證很好理解。使用攔截器驗證當前請求的許可權。代碼示例:

public class SsoAuthorizeInterceptor extends HandlerInterceptorAdapter {

    @Autowired
    private TicketHandler ticketHandler;

    @Autowired
    private SsoAuthorizeManager authorizeManager;

    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        if (!(handler instanceof HandlerMethod)) return false;

        HandlerMethod handlerMethod = (HandlerMethod) handler;
        SsoAuthorize authorize = handlerMethod.getMethodAnnotation(SsoAuthorize.class);
        if (authorize != null) {
            TicketInfo ticketInfo = ticketHandler.getTicket(request);
            if (ticketInfo == null) {
                throw new UnAuthorizedException("用戶信息已失效.");
            }

            String[] requirePermissions = authorize.permissions();
            if(requirePermissions.length==0)return true;

            boolean isCheckAll = authorize.isCheckAll();
            UserPermissionChecker permissionChecker = authorizeManager.getUserPermissionChecker();
            if(!permissionChecker.hasPermissions(ticketInfo.getUserId(),requirePermissions,isCheckAll)){
                throw new ForbiddenException("用戶沒有當前操作的許可權.");
            }
        }

        return true;
    }
}

源碼地址

本博客涉及到的前端許可權控制思路均已在:

https://github.com/liuxx001/bird-front

項目中實現,項目中除了按鈕級許可權方案還提供了後臺業務系統開發中常用的數據組件,包括:

下拉選擇器:bird-selector。

https://github.com/liuxx001/bird-front/blob/master/doc/bird-selector.md

全自動數據表格:bird-grid。

https://github.com/liuxx001/bird-front/blob/master/doc/bird-grid.md

全自動樹表:bird-tree-grid。

https://github.com/liuxx001/bird-front/blob/master/doc/bird-tree-grid.md

數據樹:bird-tree。

https://github.com/liuxx001/bird-front/blob/master/doc/bird-tree.md

全自動表單:bird-form。

https://github.com/liuxx001/bird-front/blob/master/doc/bird-form.md

許可權按鈕:bird-button。

https://github.com/liuxx001/bird-front/blob/master/doc/bird-button.md

所有業務組件的理念均是結合服務端介面進行組件的封裝,兼顧靈活性的同時保證更優的業務開發速度。

歡迎指正,提出不同的看法。

推薦閱讀(點擊即可跳轉閱讀)

 

1. SpringBoot內容聚合

2. 面試題內容聚合

3. 設計模式內容聚合

4. Mybatis內容聚合

5. 多線程內容聚合

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 數據綁定是將視圖和數據相關聯,當數據發生變化時,可以自動更新視圖,本文介紹vue,js中數據綁定的語法 (1)插值 文本插值是最基本的形式 使用雙大括弧{{}},例如<span>數據:{{text}}</span>,當text的值改變時,文本中的值也會聯動的發生變化。例如: 大括弧裡面的值被替換為《 ...
  • 效果圖 HTMl5結婚微信電子請柬模板源碼↑ 點擊下載 HTMl5結婚微信電子請柬模板源碼基於最新版Animate CC設計,採用HTML5 Canvas+ASP製作。 請柬能夠有效識別pc和移動設備,在頁面中添加自動適應代碼,請柬中採用幻燈片輪播方式,包含片頭和結尾,帶有音樂控制開關。用戶可以通過 ...
  • 面向對象,OOP,我知道,我知道,我知道....... 你真的知道嗎?你確定知道嗎?你確定你是真的知道嗎? 經過了,靈魂三連問,開始一起看看什麼是面向對象編程~ ...
  • 一、小案例分析 1、功能需求: 現有一個員工,姓名為Rick,年齡22,ID為193211,如何創建10個完全相同的對象。 2、小菜雞的答案: (1)直接new 10個對象就完了。(2)代碼實現: (3)代碼分析: 容易理解,好操作。但是每次都是初始化對象,而不是動態獲得對象,不夠靈活,效率低。 二 ...
  • 裝飾器模式的目的——**核心部分和裝飾部分可以自由組合。** 裝飾器模式要求: - 裝飾可選 - 裝飾可擴展 - 核心部分可擴展 ...
  • 顧名思義,創建型模式的聚焦點在如何創建對象能夠將對象的創建與使用最大化的分離從而降低系統的耦合度。 ...
  • 前言 我們終於學習最後一個設計原則了,其實博主更新的還是挺慢的,因為我想一個一個吃透以後再繼續學習,切記不要囫圇吞棗。 基本介紹 其實這個能說的內容很少,就是: 儘量使用合成/聚合的方式,而不是使用繼承 為什麼要這樣做?有一下兩點原因: 1. 通過繼承來進行復用的主要問題在於繼承復用會破壞系統的封裝 ...
  • 前言 迪米特法則,聽名字有點奇怪,但是這個法則真的非常非常有意思,在我看來,這個法則其實描述的就是一個矜持的小姑娘,害羞的惹人憐愛。但是啊,姑娘雖好,切不可"貪杯"哦~ 基本介紹 1. 一個對象應該對其他對象保持最少的瞭解。 2. 類與類關係越密切,耦合度越大 3. 一個類對自己依賴的類知道的越少越 ...
一周排行
    -Advertisement-
    Play Games
  • 前言 在我們開發過程中基本上不可或缺的用到一些敏感機密數據,比如SQL伺服器的連接串或者是OAuth2的Secret等,這些敏感數據在代碼中是不太安全的,我們不應該在源代碼中存儲密碼和其他的敏感數據,一種推薦的方式是通過Asp.Net Core的機密管理器。 機密管理器 在 ASP.NET Core ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 順序棧的介面程式 目錄順序棧的介面程式頭文件創建順序棧入棧出棧利用棧將10進位轉16進位數驗證 頭文件 #include <stdio.h> #include <stdbool.h> #include <stdlib.h> 創建順序棧 // 指的是順序棧中的元素的數據類型,用戶可以根據需要進行修改 ...
  • 前言 整理這個官方翻譯的系列,原因是網上大部分的 tomcat 版本比較舊,此版本為 v11 最新的版本。 開源項目 從零手寫實現 tomcat minicat 別稱【嗅虎】心有猛虎,輕嗅薔薇。 系列文章 web server apache tomcat11-01-官方文檔入門介紹 web serv ...
  • C總結與剖析:關鍵字篇 -- <<C語言深度解剖>> 目錄C總結與剖析:關鍵字篇 -- <<C語言深度解剖>>程式的本質:二進位文件變數1.變數:記憶體上的某個位置開闢的空間2.變數的初始化3.為什麼要有變數4.局部變數與全局變數5.變數的大小由類型決定6.任何一個變數,記憶體賦值都是從低地址開始往高地 ...
  • 如果讓你來做一個有狀態流式應用的故障恢復,你會如何來做呢? 單機和多機會遇到什麼不同的問題? Flink Checkpoint 是做什麼用的?原理是什麼? ...
  • C++ 多級繼承 多級繼承是一種面向對象編程(OOP)特性,允許一個類從多個基類繼承屬性和方法。它使代碼更易於組織和維護,並促進代碼重用。 多級繼承的語法 在 C++ 中,使用 : 符號來指定繼承關係。多級繼承的語法如下: class DerivedClass : public BaseClass1 ...
  • 前言 什麼是SpringCloud? Spring Cloud 是一系列框架的有序集合,它利用 Spring Boot 的開發便利性簡化了分散式系統的開發,比如服務註冊、服務發現、網關、路由、鏈路追蹤等。Spring Cloud 並不是重覆造輪子,而是將市面上開發得比較好的模塊集成進去,進行封裝,從 ...
  • class_template 類模板和函數模板的定義和使用類似,我們已經進行了介紹。有時,有兩個或多個類,其功能是相同的,僅僅是數據類型不同。類模板用於實現類所需數據的類型參數化 template<class NameType, class AgeType> class Person { publi ...
  • 目錄system v IPC簡介共用記憶體需要用到的函數介面shmget函數--獲取對象IDshmat函數--獲得映射空間shmctl函數--釋放資源共用記憶體實現思路註意 system v IPC簡介 消息隊列、共用記憶體和信號量統稱為system v IPC(進程間通信機制),V是羅馬數字5,是UNI ...