數(shù)據(jù)權(quán)限控制

1. 數(shù)據(jù)權(quán)限是什么?

在講數(shù)據(jù)權(quán)限之前岩臣,要先說一下功能權(quán)限宵膨;功能權(quán)限一般的管理后臺系統(tǒng)都會涉及到炸宵;即:某個(gè)人擁有什么角色,可以對哪些資源進(jìn)行操作捎琐;
數(shù)據(jù)權(quán)限和功能權(quán)限一樣,也是一種對資源的保護(hù)末秃;數(shù)據(jù)權(quán)限又可以分為“橫向權(quán)限”和“縱向權(quán)限”

橫向權(quán)限:即對數(shù)據(jù)行級別的限制

例如:角色A可以查看全部數(shù)據(jù)籽御;角色B只能查看50條數(shù)據(jù);

縱向權(quán)限:即數(shù)據(jù)列級別的限制

例如:角色C可以查看所有列铃将,角色D只能查看3列數(shù)據(jù)

2. 數(shù)據(jù)權(quán)限如何設(shè)計(jì)哑梳?

個(gè)人理解:
既然數(shù)據(jù)權(quán)限和功能權(quán)限一樣,那么權(quán)限表(permission)里就可以創(chuàng)建一條數(shù)據(jù)悯仙,類型定義為“數(shù)據(jù)權(quán)限”吠卷,至于數(shù)據(jù)規(guī)則的具體邏輯可以單獨(dú)用一個(gè)表(data_rule)存儲,然后data_rule 表里面引入permission表 Id字段
具體執(zhí)行邏輯:

  1. 用戶訪問一個(gè)資源
  2. 判斷該用戶是否有權(quán)限訪問該資源(即:功能權(quán)限)
  3. 如果可以訪問偎捎,判斷該接口是否啟用了數(shù)據(jù)權(quán)限規(guī)則
  4. 如果啟用數(shù)據(jù)規(guī)則序攘,獲取該用戶擁有的角色,通過角色獲取數(shù)據(jù)規(guī)則權(quán)限
  5. 通過數(shù)據(jù)規(guī)則丈牢,動(dòng)態(tài)修改查詢SQL
  6. 執(zhí)行SQL瞄沙,返回結(jié)果;
    以上邏輯是否覺得有哪塊不對?
    在第四步的時(shí)候申尼,通過角色獲取數(shù)據(jù)規(guī)則垫桂,數(shù)據(jù)規(guī)則可能有多個(gè),那應(yīng)該怎么處理霹粥?
    例如:
    1)一個(gè)用戶是銷售經(jīng)理, 他可以看他以及他下屬的銷售業(yè)績庙曙; 對應(yīng)一條數(shù)據(jù)權(quán)限1
    2)查看客戶信息時(shí)浩淘,他能查看他下屬的客戶信息; 對應(yīng)一條數(shù)據(jù)權(quán)限2
    當(dāng)用戶訪問銷售業(yè)績的時(shí)候男旗,如果按照之前的理論欣鳖,應(yīng)該會得到兩條數(shù)據(jù)權(quán)限;但是這并不是我們想要的什荣,我們只想得到數(shù)據(jù)權(quán)限1就可以怀酷。所以數(shù)據(jù)權(quán)限應(yīng)該是與接口對應(yīng)的蜕依,即:數(shù)據(jù)權(quán)限作用在哪個(gè)具體的接口上,這樣當(dāng)我們獲取到2條數(shù)據(jù)權(quán)限時(shí)样眠,通過接口URL進(jìn)行過濾檐束,就可以找到只屬于這個(gè)接口的數(shù)據(jù)權(quán)限了;

3. 開源框架jeecg-boot 是如何做的被丧?

下圖是jeecgboot 表設(shè)計(jì)的大致:


圖片.png

jeecg-boot框架里面的具體邏輯:

  1. 在使用數(shù)據(jù)權(quán)限的接口上用自定義注解@PermissionData標(biāo)識
  2. 編寫一個(gè)切面類PermissionDataAspect甥桂,攔截@PermissionData標(biāo)識的接口
  3. 當(dāng)用戶訪問一個(gè)帶有注解PermissionData的接口黄选,首先會進(jìn)入PermissionDataAspect類,該類的主要作用就是通過接口URL獲取作用在這條接口上的數(shù)據(jù)權(quán)限,然后把數(shù)據(jù)權(quán)限(即:數(shù)據(jù)規(guī)則)保存到上下文中。
  4. 當(dāng)進(jìn)入到真正的接口中時(shí)蜂嗽,獲取數(shù)據(jù)規(guī)則殃恒,通過數(shù)據(jù)規(guī)則動(dòng)態(tài)生成Sql語句。
  5. 執(zhí)行sql 并返回結(jié)果
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末病附,一起剝皮案震驚了整個(gè)濱河市完沪,隨后出現(xiàn)的幾起案子嵌戈,更是在濱河造成了極大的恐慌,老刑警劉巖宽档,帶你破解...
    沈念sama閱讀 211,042評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件庵朝,死亡現(xiàn)場離奇詭異,居然都是意外死亡椎瘟,警方通過查閱死者的電腦和手機(jī)昔逗,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,996評論 2 384
  • 文/潘曉璐 我一進(jìn)店門勾怒,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人笔链,你說我怎么就攤上這事鉴扫。” “怎么了炕婶?”我有些...
    開封第一講書人閱讀 156,674評論 0 345
  • 文/不壞的土叔 我叫張陵,是天一觀的道長项滑。 經(jīng)常有香客問我涯贞,道長,這世上最難降的妖魔是什么宋渔? 我笑而不...
    開封第一講書人閱讀 56,340評論 1 283
  • 正文 為了忘掉前任州疾,我火速辦了婚禮,結(jié)果婚禮上皇拣,老公的妹妹穿的比我還像新娘严蓖。我一直安慰自己,他們只是感情好审磁,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,404評論 5 384
  • 文/花漫 我一把揭開白布谈飒。 她就那樣靜靜地躺著,像睡著了一般态蒂。 火紅的嫁衣襯著肌膚如雪杭措。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,749評論 1 289
  • 那天钾恢,我揣著相機(jī)與錄音,去河邊找鬼瘩蚪。 笑死泉懦,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的疹瘦。 我是一名探鬼主播崩哩,決...
    沈念sama閱讀 38,902評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼言沐!你這毒婦竟也來了邓嘹?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,662評論 0 266
  • 序言:老撾萬榮一對情侶失蹤险胰,失蹤者是張志新(化名)和其女友劉穎汹押,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體起便,經(jīng)...
    沈念sama閱讀 44,110評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡棚贾,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,451評論 2 325
  • 正文 我和宋清朗相戀三年窖维,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片妙痹。...
    茶點(diǎn)故事閱讀 38,577評論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡铸史,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出怯伊,到底是詐尸還是另有隱情沛贪,我是刑警寧澤,帶...
    沈念sama閱讀 34,258評論 4 328
  • 正文 年R本政府宣布震贵,位于F島的核電站,受9級特大地震影響水评,放射性物質(zhì)發(fā)生泄漏猩系。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,848評論 3 312
  • 文/蒙蒙 一中燥、第九天 我趴在偏房一處隱蔽的房頂上張望寇甸。 院中可真熱鬧,春花似錦疗涉、人聲如沸拿霉。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,726評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽绽淘。三九已至,卻和暖如春闹伪,著一層夾襖步出監(jiān)牢的瞬間沪铭,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,952評論 1 264
  • 我被黑心中介騙來泰國打工偏瓤, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留杀怠,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,271評論 2 360
  • 正文 我出身青樓厅克,卻偏偏與公主長得像赔退,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子证舟,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,452評論 2 348

推薦閱讀更多精彩內(nèi)容