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

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

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

    Grails中如何使用acegi requestmap 進行動態配置權限

      考慮到權限應該可以由用戶自行分配,所以靜態的requestmap 和 controller annotations 的方法都不太合適。因此使用動態的requestmap,于是出現了一些小問題,如本文所描述:

    1. 安裝acegi plugin

    2. acegi的一些概念以及用法參考
    http://grails.org/plugin/acegi
    http://www.infoq.com/cn/articles/grails-acegi-integration

    3. 問題
      在grails中,默認生成的show.gsp中是使用一個form帶多個參數來提交,比如?_action_Edit=edit 或者 ?_action_Delete=delete,
    但對于requestmap,它實際是對于url進行限制的,并沒有對參數做限制,所以這時候 grails提交的action就不會被requestmap檢測到。

    4. 方案
     
       requestmap權限分配機制類似如下,這里只是demo。
       實際中,可以在UI界面上通過使用checkbox來代替該requestmap的URI string,完成對role進行權限的分配。
     
     1 def projectListMap = new Requestmap(
     2                      url: '/project/list**',
     3                      configAttribute: 'ROLE_USER, ROLE_ADMIN'
     4              )
     5              projectListMap.save()
     6              
     7              
     8 def projectCreateMap = new Requestmap(
     9                      url: '/project/create**',
    10                      configAttribute: 'ROLE_ADMIN'
    11              )
    12              projectCreateMap.save()
    13              
    14 def projectEditMap = new Requestmap(
    15                      url: '/project/edit**',
    16                      configAttribute: 'ROLE_ADMIN'
    17              )

      采用原生的html form代替grails的actionSubmit,顯示的提交url,比如
      使用
    1       <form action="/todolist/project/edit">
    2         ..
    3       </form>
    4       <form action="/todolist/project/delete" method="post" >
    5         ..
    6       </form>
         
    代替原來的     
                 
    1 <g:form>
    2    <g:hiddenField name="id" value="${projectInstance?.id}" />
    3   <span class="button"><g:actionSubmit class="edit" action="edit" value="${message(code: 'default.button.edit.label', default: 'Edit')}" /></span>
    4   <span class="button"><g:actionSubmit class="delete" action="delete" value="${message(code: 'default.button.delete.label', default: 'Delete')}" onclick="return confirm('${message(code: 'default.button.delete.confirm.message', default: 'Are you sure?')}');" /></span>
    5 </g:form>

           
     4.參考
    http://grails.1312388.n4.nabble.com/acegi-requestmap-how-to-inspect-URL-parameters-td1382988.html

    5. 關于這種方式,有一些缺點,就是使用原來的方式可以繞開requestmap的限制,具體請看
    http://grails.1312388.n4.nabble.com/Unexpected-observations-using-spring-security-acegi-plugin-td1349785.html






    posted on 2010-06-30 15:05 想飛就飛 閱讀(1656) 評論(0)  編輯  收藏 所屬分類: J2EE

    公告


    導航

    <2010年6月>
    303112345
    6789101112
    13141516171819
    20212223242526
    27282930123
    45678910

    統計

    常用鏈接

    留言簿(13)

    我參與的團隊

    隨筆分類(69)

    隨筆檔案(68)

    最新隨筆

    搜索

    積分與排名

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 久久成人免费播放网站| 大片免费观看92在线视频线视频| 在线观看免费播放av片| ZZIJZZIJ亚洲日本少妇JIZJIZ| 精品国产日韩亚洲一区91| 免费一级毛片在级播放| 一区二区三区在线免费观看视频 | 免费va在线观看| 国产亚洲人成在线影院| 亚洲第一永久AV网站久久精品男人的天堂AV | 日韩成人精品日本亚洲| 免费一级特黄特色大片在线观看| 美女羞羞免费视频网站| 亚洲国产专区一区| 成人久久免费网站| 久久亚洲AV无码精品色午夜麻豆 | 免费网站看v片在线香蕉| 亚洲爆乳大丰满无码专区| va亚洲va日韩不卡在线观看| 国产福利免费视频 | 91成年人免费视频| 亚洲七久久之综合七久久| 免费**毛片在线播放直播| 中国人免费观看高清在线观看二区| 亚洲国产精品特色大片观看完整版 | 日韩亚洲Av人人夜夜澡人人爽| 97视频热人人精品免费| 深夜特黄a级毛片免费播放| 国产亚洲精品国产| 免费无码黄十八禁网站在线观看| 日日摸日日碰夜夜爽亚洲| 亚洲日韩精品无码专区网址| 永久黄色免费网站| 真人无码作爱免费视频| 黑人大战亚洲人精品一区 | 亚洲国产成人久久综合碰| 四虎影视在线影院在线观看免费视频| 亚洲国产精品久久久久秋霞影院| 永久久久免费浮力影院| 97无码人妻福利免费公开在线视频 | 日本高清在线免费|