欧美性猛交XXXX免费看蜜桃,成人网18免费韩国,亚洲国产成人精品区综合,欧美日韩一区二区三区高清不卡,亚洲综合一区二区精品久久

打開(kāi)APP
userphoto
未登錄

開(kāi)通VIP,暢享免費電子書(shū)等14項超值服

開(kāi)通VIP
JAAS -數據庫方式驗證
2007-09-11

JAAS http://bluepopopo.javaeye.com/blog/122993

關(guān)鍵字: jboss jaas
項目中用到了JAAS,以前沒(méi)有接觸過(guò),google了半天資料。趕快紀錄下來(lái):

1.JAAS全稱(chēng)為Java authentication and authorization service,用于設計可拔插的安全機制。一般項目中用在web端或ejb訪(fǎng)問(wèn)控制。

2.直接以例子進(jìn)行(基于JBoss4.0.0):

   2.1 首先確定需要以何種方式進(jìn)行驗證,文件/數據庫/LDAP。目前的項目是用數據庫方式。

   2.2  在JBoss中以文件方式驗證,可以參考jmx-console.war的配置:將jboss-web.xml中的注釋去掉,然后再把web.xml中的那一段注釋拿掉。確認classes目錄下的jmx-console-users.properties和jmx-console-roles.properties存在。

   2.3重起jboss,http://localhost:8080 點(diǎn)擊jmx-console鏈接,則需要安全驗證。


3.在web應用中使用基于database方式的JAAS:
   3.1 創(chuàng )建role table:

      CREATE TABLE Principals (PrincipalID VARCHAR (64) PRIMARY KEY,Password VARCHAR (64));     
      INSERT INTO Principals VALUES ('admin', '123');
      INSERT INTO Principals VALUES ('guest', '456') ;
      CREATE TABLE Roles (PrincipalID VARCHAR (64), Role VARCHAR (64), RoleGroup VARCHAR (64));
      INSERT INTO Roles VALUES ('admin', 'admin', 'Roles');
      INSERT INTO Roles VALUES ('guest', 'guest', 'CallerPrincipal');

    3.2 創(chuàng )建一個(gè)datasource文件??梢詮?lt;%jboss_home%>/server/docs/examples/jca 目錄下拷貝一個(gè)至deploy目錄。Ds文件的內容作相應修改。

    3.3 修改<%jboss_home%>/server/你的服務(wù)/conf/login-config.xml,添加:
    <application-policy name="MyEJB">  
     <authentication>    
      <login-module code="org.jboss.security.auth.spi.DatabaseServerLoginModule" flag="required">
        <module-option name = "dsJndiName">java:/MSSQLDS</module-option>
        <module-option name = "principalsQuery">SELECT Password FROM Principals WHERE  PrincipalID=?</module-option>
        <module-option name = "rolesQuery">SELECT Role,RoleGroup FROM Roles WHERE PrincipalID=?</module-option>
      </login-module>
     </authentication>
     </application-policy>


     3.4  仿照jmx-console的配置,將jboss-web.xml,和 web.xml中注釋掉的security內容拷貝過(guò)來(lái)。其中為:java:/jaas/ MyEJB 與 login-config.xml的設置對應,為super與數據庫對應。

     3.5 重起jboss.訪(fǎng)問(wèn)web應用.

4.在EJB中使用
     4.1  需要在ejb-jar.xml,jboss.xml中添加屬性。
     ejb-jar.xml:
     <ejb-jar>
     <enterprise-beans>
          <session>
                 <ejb-name>BookService</ejb-name>
                 <home>com.shawn.BookRemoteHome</home>
                 <remote>com.shawn.BookRemoteObject</remote>
                 <ejb-class>com.shawn.BookServiceBean</ejb-class>
                 <session-type>Stateless</session-type>
                 <transaction-type>Container</transaction-type>
                 <security-role-ref>
                        <role-name>super</role-name>
                        <role-link>super</role-link>
                 </security-role-ref>
          </session>
      </enterprise-beans>
      <assembly-descriptor>
          <security-role>
                 <description>Administrator</description>
                 <role-name>super</role-name>
          </security-role>
          <method-permission>
                 <description>addbook</description>
                 <role-name>super</role-name>
                 <method>
                        <ejb-name>BookService</ejb-name>
                        <method-name>*</method-name>
                 </method>
          </method-permission>
       </assembly-descriptor>
       </ejb-jar>


相應的jboss.xml:
      <jboss>    
       <security-domain>java:/jaas/MyEJB</security-domain>
       <enterprise-beans>
          <session>
                 <ejb-name>BookService</ejb-name>
                 <jndi-name>BookService</jndi-name>
          </session>
        </enterprise-beans>
        <assembly-descriptor>
           <security-role>
                 <role-name>super</role-name>
                 <principal-name>super</principal-name>
          </security-role>
        </assembly-descriptor>
        </jboss>


    4.2 寫(xiě)一個(gè)servlet(LoginServlet)訪(fǎng)問(wèn)該ejb.
        Properties pro = System.getProperties();
        pro.setProperty(Context.INITIAL_CONTEXT_FACTORY, "org.jnp.interfaces.NamingContextFactory");
        pro.setProperty(Context.PROVIDER_URL, "jnp://localhost:1099");
        Context con = new InitialContext(pro);
        Object obj = con.lookup("BookService");
        BookRemoteHome home = (BookRemoteHome)PortableRemoteObject.narrow(obj, BookRemoteHome.class);
        BookRemoteObject bookService= home.create();
        System.out.println("Create home successfully!");
              . . .只貼點(diǎn)關(guān)鍵代碼     

     4.3 部署ejb和web應用,啟動(dòng)JBoss,訪(fǎng)問(wèn)web時(shí)需要jaas登陸,訪(fǎng)問(wèn)LoginServlet時(shí)調用ejb則會(huì )使用ejb的jaas的檢驗。

5.當然jaas允許編寫(xiě)自定義的login module,總的說(shuō)來(lái)就是:
      實(shí)現LoginModule接口,實(shí)現其中的initilize(),login() . . . 方法;
      實(shí)現 CallbackHandler接口,實(shí)現其中的handle()方法;
      實(shí)現Principal接口。

6.仍然有疑問(wèn),留待以后考慮:
     6.1客戶(hù)端直接訪(fǎng)問(wèn),譬如eclipse訪(fǎng)問(wèn)該EJB總是會(huì )報principal不匹配(No matching username found in Principals),只有在web登陸后才可以正常訪(fǎng)問(wèn)需要授權的EJB??蛻?hù)端不能利用
        pro.setProperty(Context.SECURITY_PRINCIPAL, "xxx”)
        pro.setProperty(Context.SECURITY_CREDENTIALS, "xxx”)
的方式訪(fǎng)問(wèn)?

     6.2 JBoss4.0.0設置ejb的jaas時(shí),總會(huì )是報有princpal不存在的異常,換成4.0.5GA就可以,奇怪哉?

至此完了,比較粗略,第一次紀錄自己的體會(huì )不容易啊。
本站僅提供存儲服務(wù),所有內容均由用戶(hù)發(fā)布,如發(fā)現有害或侵權內容,請點(diǎn)擊舉報。
打開(kāi)APP,閱讀全文并永久保存 查看更多類(lèi)似文章
猜你喜歡
類(lèi)似文章
Implementing J2EE security using JAAS on JBOS...
定制自己的WebLogic LDAP Authentication Provider
Jetspeed2學(xué)習筆記(一)
web.xml 中的listener、 filter、servlet 加載順序及其詳解
Servlet2.4中web.xml配置及說(shuō)明
serverlet配置文件
更多類(lèi)似文章 >>
生活服務(wù)
分享 收藏 導長(cháng)圖 關(guān)注 下載文章
綁定賬號成功
后續可登錄賬號暢享VIP特權!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服

欧美性猛交XXXX免费看蜜桃,成人网18免费韩国,亚洲国产成人精品区综合,欧美日韩一区二区三区高清不卡,亚洲综合一区二区精品久久