学习EJB CMP/CMR 的心得体会

类别:Java 点击:0 评论:0 推荐:

    本人学习EJB也有一年多的时间了,前段时间公司接到一个大的项目才真正的用到,客户使用的Weblogic 7.0,数据库用的是SQL Server 2000,所以我只能正对Weblogic+SQL Server 2000的环境来做说明。

       首先,在Weglogic中配置数据源,在Weblogic中有Sql Server 2000的JDBC,所以就可以直接使用,注意,在EJB中一定要使用Tx-DataSource,另外,还要对Sql Server 2000数据库打一个JTA的补丁,这样才能更好的支持分布式事务的处理。

       下面,我就对我们系统中的一个认证子系统做一个简单的介绍,(参考:http://www-900.ibm.com/developerWorks/cn/cnedu.nsf/java-onlinecourse-bytitle/991A4E2DCA2D6CE148256BCE00135FAE?OpenDocument)我基本上是根据这个例子来做的。

       在本子系统中,LocalUserBean(实体)用来验证用户身份,UserInfoBean(实体)用户详细信息,UserGroupBean(实体)用户分组,LocalRoleBean(实体)用户角色,UserManageBean(会话)该子系统的唯一远程接口。

       关系:LocalUserBean ----- UserInfoBean 是 one2one的单相关系,UserGroupBean----LocalUserBean是one2many的双相关系,LocalUserBean----LocalRoleBean是many2many的双相关系。

       LocalUserBean----UserInfoBean:一对一的关系比较简单

  LocalUserBean的字段 (CMP)

  public abstract void setEmail(java.lang.String email);

  public abstract void setPw(java.lang.String pw);

  public abstract java.lang.String getEmail();

  public abstract java.lang.String getPw();

 

  与UserInfo建立关系 (CMR)

  public abstract void setUserInfo(usermanagesample.UserInfo userInfo);

  public abstractUserInfo getUserInfo();

 

UserInfoBean的字段 (CMP)

  public abstract void setEmail(java.lang.String email);

  public abstract void setDept(java.lang.String dept);

  public abstract void setName(java.lang.String Name);

              ……

  public abstract java.lang.String getEmail();

  public abstract java.lang.String getDept();

  public abstract java.lang.String getName();

       ……

 由于关系是单的,所以UserInfoBean没有CMR字段。

 

 Weblogic-cmp-rdbms-jar.xml

   <weblogic-rdbms-bean>

        <ejb-name>LocalUser</ejb-name>

        <data-source-name>WL-TX-SqlServer-DataSource</data-source-name>

        <table-map>

            <table-name>localuser</table-name>

            <field-map>

                <cmp-field>email</cmp-field>

                <dbms-column>EMAIL</dbms-column>

            </field-map>

            <field-map>

                <cmp-field>pw</cmp-field>

                <dbms-column>PW</dbms-column>

            </field-map>

        </table-map>

</weblogic-rdbms-bean>

   <weblogic-rdbms-bean>

<ejb-name>UserInfo</ejb-name>        <data-source-name>WL-TX-SqlServer-DataSource</data-source-name>

        <table-map>

            <table-name>userinfo</table-name>

            <field-map>

                <cmp-field>email</cmp-field>

                <dbms-column>EMAIL</dbms-column>

            </field-map>

            <field-map>

                <cmp-field>dept</cmp-field>

                <dbms-column>DEPT</dbms-column>

            </field-map>

            <field-map>

                <cmp-field>name</cmp-field>

                <dbms-column>uname</dbms-column>

            </field-map>

        </table-map>

    </weblogic-rdbms-bean>

 

    <weblogic-rdbms-relation>

        <relation-name>userInfo-localUser</relation-name>

        <weblogic-relationship-role>

            <relationship-role-name>LocalUserRelationshipRole</relationship-role-name>

            <relationship-role-map>

                <foreign-key-table>localuser</foreign-key-table>

                <primary-key-table>userinfo</primary-key-table>

                <column-map>

                    <foreign-key-column>EMAIL</foreign-key-column>

                    <key-column>EMAIL</key-column>

                </column-map>

            </relationship-role-map>

        </weblogic-relationship-role>

</weblogic-rdbms-relation>

 

LocalUserBean中的方法:

ejbCreate(String email,String pw,UserInfoValueObject user){

   setEmail(email);

      setPw(pw)

}

 

ejbPostCreate(String email,String pw,UserInfoValueObject user){

      Context ctx=new InitialContext();

LocalRoleHome home=(LocalRoleHome)ctx.lookup(“LocalRole”);

home.create(user.getEmail,…………);

}

通过ejbPostCreate的方法,调用LocalRoleBean的本地接口,同时创建用户信息,UserInfoValueObject为自己定义的一个用户信息类,记住,这个类一定要实现java.io. Serializable,因为EJB中要求对象都可以序列化。

 

UserManage中的方法

添家用户。添加LocalUser的同时,也添加了UserInfo

       public void addUser(String email, String pw, UserInfoValueObject user) {

    try{

      LocalUser user=userHome.create(email, pw,user);

      }catch(CreateException ce){

      throw new EJBException("创建用户"+email+"错误!",ce);

}

}

 

删除用户。删除LocalUser的同时,也删除了UserInfo

public void removeUser(String email){

try{

      userHome.remove(email);

          }catch(CreateException ce){

      throw new EJBException("删除用户"+email+"错误!",ce);

}

  }

 

校验用户密码

public boolean verifyUser(String email, String pw) {

    try{

      LocalUser user = userHome.findByPrimaryKey(email);

      return user.getPw().equals(pw);

    }catch(FinderException fe){

      throw new EJBException("校验用户"+email+"错误!",fe);

    }

  }

 

LocalUser----LocalRole的关系为many2many的双相关系。

     在开始编写EJB CMP的时候,由于我对many2many的关系映射总是失败,所以在项目当中我都避免出现many2many的关系,后来发现EJB中的关系其实就是实现了数据库中的关系,所以对数据库的基础要了解的话,实现起来也不复杂。

LocalRoleBean: (CMP)

  public abstract void setRolename(java.lang.String rolename);

  public abstract void setDescription(java.lang.String description);

  public abstract java.lang.String getRolename();

  public abstract java.lang.String getDescription();

 

(CMR)

  public abstract java.util.Collection getLocalUser();

  public abstract void setLocalUser(java.util.Collection localUser);

 

在LocalUserBean中加,因为是many2many的关系,所以是Collection接口;

  public abstract void setRoletab(java.util.Collection roletab);

  public abstract java.util.Collection getRoletab();

 

Weblogic-cmp-rdbms-jar.xml

   <weblogic-rdbms-bean>

        <ejb-name>Roletab</ejb-name>

        <data-source-name>WL-TX-SqlServer-DataSource</data-source-name>

        <table-map>

            <table-name>roletab</table-name>

            <field-map>

                <cmp-field>rolename</cmp-field>

                <dbms-column>ROLENAME</dbms-column>

            </field-map>

            <field-map>

                <cmp-field>description</cmp-field>

                <dbms-column>DESCRIPTION</dbms-column>

            </field-map>

        </table-map>

</weblogic-rdbms-bean>

 

   <weblogic-rdbms-relation>

        <relation-name>localUser-roletab</relation-name>

        <table-name>middletab</table-name>

        <weblogic-relationship-role>

            <relationship-role-name>LocalUserRelationshipRole</relationship-role-name>

            <relationship-role-map>

                <foreign-key-table>middletab</foreign-key-table>

                <primary-key-table>localuser</primary-key-table>

                <column-map>

                    <foreign-key-column>localuserid</foreign-key-column>

                    <key-column>EMAIL</key-column>

                </column-map>

            </relationship-role-map>

        </weblogic-relationship-role>

        <weblogic-relationship-role>

            <relationship-role-name>RoletabRelationshipRole</relationship-role-name>

            <relationship-role-map>

                <foreign-key-table>middletab</foreign-key-table>

                <primary-key-table>roletab</primary-key-table>

                <column-map>

                    <foreign-key-column>roleid</foreign-key-column>

                    <key-column>ROLENAME</key-column>

                </column-map>

            </relationship-role-map>

        </weblogic-relationship-role>

    </weblogic-rdbms-relation>

 

UserManage中实现的方法(略);

 

UserGroup----LocalUser是one2many的双相关系;

  (CMP)

  public abstract void setName(java.lang.String name);

  public abstract void setDescription(java.lang.String description);

  public abstract java.lang.String getName();

  public abstract java.lang.String getDescription();

 

  (CMR)

  public abstract java.util.Collection getLocalUser();

  public abstract void setLocalUser(java.util.Collection localUser);

 

Weblogic-cmp-rdbms-jar.xml

    <weblogic-rdbms-bean>

        <ejb-name>LocalGroup</ejb-name>

        <data-source-name>WL-TX-SqlServer-DataSource</data-source-name>

        <table-map>

            <table-name>localgroup</table-name>

            <field-map>

                <cmp-field>name</cmp-field>

                <dbms-column>name</dbms-column>

            </field-map>

            <field-map>

                <cmp-field>description</cmp-field>

                <dbms-column>description</dbms-column>

            </field-map>

        </table-map>

</weblogic-rdbms-bean>

 

    <weblogic-rdbms-relation>

        <relation-name>localUser-localGroup</relation-name>

        <weblogic-relationship-role>

            <relationship-role-name>LocalUserRelationshipRole</relationship-role-name>

            <relationship-role-map>

                <foreign-key-table>localuser</foreign-key-table>

                <primary-key-table>localgroup</primary-key-table>

                <column-map>

                    <foreign-key-column>LOCAL_GROUP</foreign-key-column>

                    <key-column>name</key-column>

                </column-map>

            </relationship-role-map>

        </weblogic-relationship-role>

    </weblogic-rdbms-relation>

 

总结:首先要对EJB CMP/CMR的实现原理充分了解,其次要了解数据库原理中关系是如何定义的,这样对于你实现关系的映射非常有好处,第三,就是要看别人的代码和例子,多看相关的介绍文章,多做例子。

由于本人的知识和水平有限,还请大家不吝指教和批评。

我的联系方式:[email protected](msn)

希望能和大家共同探讨和学习

本文地址:http://com.8s8s.com/it/it17142.htm