Open-Open

          皇家撒拉哥薩
          posts - 32, comments - 3, trackbacks - 0, articles - 1

          Jetspeed-2 心得隨筆(5)(完)-Security

          Posted on 2006-07-17 17:22 開源愛好者 閱讀(772) 評論(2)  編輯  收藏 所屬分類: Portal
          Jetspeed2 Security介紹的官方連結:
          [url]http://portals.apache.org/jetspeed-2/multiproject/jetspeed-security/[url]

          J2使用JAAS的來處理security有關的問題。以之前裝在Tomcat上的J2為例,可以由c:\tomcat\conf\Catalina\localhost\jetspeed.xml及C:\tomcat\webapps\jetspeed\WEB-INF\web.xml看到有關JAAS Realm及login的設定。

          大致上來說,JAAS包含Principal、Permission、Policy三個概念。在J2中有user、role、group三種Principal。而Permission基本上有page、portlet,tab等等,當然也可以增加自訂的Permission。至於Policy,J2並沒有使用JAAS的policy檔,而是使用自帶的RdbmsPolicy,也就是把Policy的資訊存在資料庫中;而透過"適當"的實作和設定,J2也可以使用相關App Server的JAAS。

          底下是官方的security元件架構圖:

          在J2中,核心的部份就是"J2 Security Coarsed Services"裡的4個Manager元件。J2的JAAS login module實際上是使用UserManager來進行authentication;UserManager透過OJB自資料庫中取出user的資料例如UserPrincipal、Crendential等並進行authorization.

          當透過UserManager認證完成以後,J2會同時將此User相對應的所有Principal取出並建立此User的Subject。此後,當SecurityValve執行時,就會呼叫JAAS的Subject.doAsPrivileged(Subject,PrivilegedAction,AccessControlContext)進行有關authorization的動作。有興趣的可以參考org.apache.jetspeed.security.impl.AbstractSecurityValve的原始碼。

          J2在security的部份也提供了SPI的設計供開發人員加入自訂的認證方式,例如使用LDAP,參考底下官方的連結http://portals.apache.org/jetspeed-2/multiproject/jetspeed-security/ldap.html可以知道如何使用LDAP來進行J2上的認證。

          關於J2,其實還有很多部份值得介紹,例如Bridge、Profiler等等。可惜這些部份小弟並不是十分的了解,期待日後有更多高手能夠對J2做更多的介紹,小弟在此先向大家跪謝啦!!Orz


          Feedback

          # re: Jetspeed-2 心得隨筆(5)(完)-Security   回復  更多評論   

          2008-12-01 17:33 by 888
          goooooooooood!!!

          # re: Jetspeed-2 心得隨筆(5)(完)-Security [未登錄]  回復  更多評論   

          2009-07-30 12:46 by roger
          thanks
          主站蜘蛛池模板: 湄潭县| 凉城县| 资中县| 深水埗区| 益阳市| 乐陵市| 禄劝| 涞源县| 亳州市| 陆丰市| 白银市| 海林市| 莱州市| 灌南县| 思南县| 全州县| 新安县| 莱芜市| 宁德市| 尚志市| 锡林郭勒盟| 达拉特旗| 泽州县| 隆林| 正安县| 寻乌县| 托克逊县| 津市市| 大同市| 富宁县| 常山县| 周至县| 富裕县| 内江市| 家居| 香河县| 乐清市| 林州市| 威远县| 开远市| 措美县|