<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    小菜毛毛技術分享

    與大家共同成長

      BlogJava :: 首頁 :: 聯系 :: 聚合  :: 管理
      164 Posts :: 141 Stories :: 94 Comments :: 0 Trackbacks
    通用數據權限管理系統設計(一)
     
    作者:逸云
     
    前言:
     本文提供一種集成功能權限和數據權限的解決方法,以滿足多層次組織中權限管理方面的集中控制。本方法是RBAC(基于角色的訪問控制方法)的進一步擴展和延伸,即在功能權限的基礎上增加數據權限的管理,實現數據權限和功能權限的集中處理。
     
    解釋:
     功能權限:能做什么的問題,如增加銷售訂單;
     數據權限:能在哪里干什么的問題,如察看北京分公司海淀銷售部張三的銷售訂單;
     
    術語:
     資源:系統中的資源,主要是各種業務對象,如銷售單、付款單等;
     操作類型:對資源可能的訪問方法,如增加、刪除、修改等;
     功能:對資源的操作,是資源與操作類型的二元組,如增加銷售單、修改銷售單等;
     數據類型:業務系統中常用的數據權限類型,如公司、部門、項目、個人等;
     數據對象:具體的業務對象,如甲公司、乙部門等等,包括所有涉及到數據權限的對象值;
     權限:角色可使用的功能,分角色的功能權限和角色的數據權限;
     角色:特定權限的集合;
     用戶:參與系統活動的主體,如人,系統等。
     
     
    通用數據權限管理系統設計(二)
     
    方法說明:
     在實際應用中,數據權限的控制點一般相對固定,如針對公司、部門、個人、客戶、供應商等,也就是說數據權限一般針對指定數據類型下的一些數據對象。
     
     本方法中,數據權限的依賴于功能權限,是對功能權限的進一步描述,說明角色在指定的功能點上的數據控制權限。
    本方法中采用“沒有明確規定即視為有效”的原則,如果沒有定義功能的數據權限,則說明該角色具有該功能的全部的權限。如果定義了功能的某種類型的數據權限,則該用戶只具有該類型下指定數據的數據權限。
     
     這段話比較繞口,下面舉個例子實際例子。
     
     某公司有北京銷售部、上海銷售部和廣州銷售部三個銷售部,現在需要定義幾種角色:
        銷售總監      -- 能察看所有銷售部的銷售訂單;
        北京銷售經理 -- 只能察看北京銷售部的所有銷售訂單;
        上海銷售經理 -- 只能察看上海銷售部的所有銷售訂單;  
        廣州銷售經理 -- 只能察看廣州銷售部的所有銷售訂單;  
     
     上述角色的定義如下:
     
         -------------------------------------------------------------------
         角色名稱             功能             數據類型     數據對象  
         -------------------------------------------------------------------
         銷售總監           察看銷售訂單                                 
         北京銷售經理       察看銷售訂單         部門         北京  
         上海銷售經理       察看銷售訂單         部門         上海     
         廣州銷售經理       察看銷售訂單         部門         廣州     
         -------------------------------------------------------------------
     
        上述定義中,銷售總監只定義了功能權限,而沒有定義數據權限,所以銷售總監能夠察看所有的銷售訂單;而其他幾位銷售經理分別定義了這一功能的數據權限,所以只能察看指定部門的銷售訂單。
     
         在實際應用中,往往會出現部門分組,組長能夠察看本組所有人員處理的銷售訂單的情況,以及某些情況下,某些人只能察看本人的銷售訂單的情況,這些特殊情況在上述的說明中無法解決,需要在設計和實現中進行處理。
     
     
        北京銷售代表 -- 只能察看北京銷售部的本人的所有銷售訂單;  
         北京銷售代表         察看銷售訂單           部門            北京     
                                                     個人                  
     
     
    通用數據權限管理系統設計(三)--數據庫設計
     
    我們先來看看傳統的基于角色的權限管理系統,如下圖所示,最簡單的基于角色的權限管理由系統功能、系統角色、系統用戶、角色功能和用戶角色五部分組成。
        圖一:基于角色的數據庫結構
    為實現數據權限控制,在設計上對基于角色的權限管理進行擴充,如下圖所示:
     
    圖二:通用數據權限管理系統數據庫設計
    對比兩張圖,我們可以看到,他們之間的主要變化為:
    1、 增加系統資源信息和操作類型信息,系統資源為樹形結構、如銷售模塊、銷售訂單等;操作類型記錄可能的操作,如增加、刪除、修改、查看、查詢等,系統功能是資源與操作類型的組合,對資源的操作就是系統功能。
    2、 增加數據對象類型和數據對象兩張表,數據對象類型記錄系統中需要控制的對象類型,如部門、庫房、員工、客戶、供應商等;數據對象記錄各對象類型的對象實例,如北京銷售部、上海銷售部、張三、李四等等。(獨立保存的好處后面會說到)
    3、 增加系統資源與數據對象類型的關聯表(多對多),本表為配置表,說明某種資源可能需要的控制點,如銷售訂單與部門類型的關聯可能涉及到分部門分配權限;銷售訂單與客戶的關聯可能涉及到按客戶分配權限等等。
    4、 增加數據對象與角色權限的關聯,這張表是真正最終實現數據權限管理的所在地。
     
    通過這種設計,能夠最小化地減少對原有權限系統的更改,并且可以很靈活地增加數據的控制點。在產品化軟件的設計中使用,能夠靈活滿足客戶的需要。
     
    下一篇文章將討論這種結構如何滿足第二部分功能需求的問題,如果時間允許,將對程序的設計做進一步闡述。
     
    本設計方法已應用于自行開發的通用供應鏈管理系統中,歡迎指正。
     
    posted on 2009-05-14 15:49 小菜毛毛 閱讀(145) 評論(0)  編輯  收藏

    只有注冊用戶登錄后才能發表評論。


    網站導航:
     
    主站蜘蛛池模板: 四虎成年永久免费网站| 少妇无码一区二区三区免费| 日韩免费一区二区三区在线 | 久久精品国产精品亚洲下载| 日韩国产欧美亚洲v片| 午夜成人免费视频| 亚洲人成电影网站久久| 妞干网免费观看视频| 亚洲国产成人久久综合| 国产片免费在线观看| 人人爽人人爽人人片A免费| 亚洲日韩国产一区二区三区| 日本一区二区三区在线视频观看免费 | 亚欧在线精品免费观看一区| 亚洲国产精品专区| 天天摸夜夜摸成人免费视频| 亚洲av成人一区二区三区观看在线 | 四虎影视免费在线| 国产成人亚洲综合a∨| 亚洲国产成人久久综合野外 | 2015日韩永久免费视频播放| 亚洲一区二区三区免费视频| 免费羞羞视频网站| 久久成人永久免费播放| 亚洲精品私拍国产福利在线| 久久精品免费全国观看国产| 亚洲精品V天堂中文字幕| 亚洲精品专区在线观看| 免费人成视频在线观看网站| 国产精品亚洲片在线va| 亚洲国产精品一区二区九九| 国产一区二区免费| 国产成人亚洲综合一区 | 亚洲av一综合av一区| 色片在线免费观看| 国产精品亚洲综合一区在线观看| 国产自偷亚洲精品页65页| 99爱免费观看视频在线| 在线观看亚洲精品专区| 亚洲国产精品成人精品无码区 | 国产亚洲日韩在线三区|