Eclipse快速上手EJB -- 4. 多对多的单向关系的CMR(2)

来源:互联网 发布:python.exe sys.argv 编辑:程序博客网 时间:2024/04/27 14:23
 

二、在UserManagementBean中添加业务方法
 
1. 增加一个 UserInfoLocalHome 的变量 userHome,并将它放入 ejbCreate 和 ejbPassivate 方法中。
 
2. 依次增加以下几个业务方法。

UserManagementBean中有关 RoleBean 的部分(很简单)

 //********************************************************************** //                     多对多的单向关系 //**********************************************************************  /**  * 创建权限  * Business method  * @throws CreateException  * @ejb.interface-method view-type = "remote"  */ public void createRole(String roleName, String description)  throws CreateException {  roleHome.create(roleName, description); }  /**  * 显示所有权限  * @throws FinderException  * @ejb.interface-method view-type="remote"  */ public ArrayList getRoles() throws FinderException {  ArrayList roleList = new ArrayList(30);  Iterator iter = roleHome.findAll().iterator();  while (iter.hasNext()) {   RoleLocal role = (RoleLocal) iter.next();   roleList.add(role.getName());  }  return roleList; } /**  * 删除权限  * @throws RemoveException  * @throws EJBException  * @ejb.interface-method view-type="remote"  */ public void removeRole(String name) throws EJBException, RemoveException {  roleHome.remove(name); } /**  * 给用户增加权限  * @throws FinderException  * @ejb.interface-method view-type="remote"  */ public void addRole(String email, String roleName) throws FinderException {  UserLocal user = userHome.findByPrimaryKey(email);  Collection roles = user.getRoles();  RoleLocal role = roleHome.findByPrimaryKey(roleName);  roles.add(role); }  /**  * 得到某个用户拥有的权限  * @throws FinderException  * @ejb.interface-method view-type="remote"  */ public ArrayList getUserRole(String email) throws FinderException{  ArrayList roleList = new ArrayList(30);  UserLocal user = userHome.findByPrimaryKey(email);  Iterator iter = user.getRoles().iterator();  while (iter.hasNext()) {   RoleLocal role = (RoleLocal) iter.next();   roleList.add(role.getName());  }  return roleList; }    
 
 
3.  好了,保存,Generate EJB Classes,启动MySql, 启动JBoss服务器, Deploy Module
如果一切正常,则会在 cmp_sample 库中自动建立两个表:roletable 和 userrole 。
role_fk 和 email_fk 是在 UserBean 中的 getRoles 的方法标记中定义的。
 
 
 
 
三、创建客户端
 
1. 右击 src 文件夹 ->新建 ->Lomboz EJB Test Client  Wizard:
  创建一个 CMPClient3.java 文件 (步骤同前两篇文章一样)。
 
2. 修改生成的 CMPClient3.java,调用UserManagementBean中的方法。
   这里给出了完整的源代码:

CMPClient3.java

/* * 创建日期 2005-1-25 * * 作者:javamxj(分享java快乐) */package javamxj.ejb.client;import java.rmi.RemoteException;import java.util.ArrayList;import java.util.Hashtable;import java.util.Iterator;import javamxj.ejb.cmp.UserManagement;import javax.ejb.CreateException;import javax.ejb.FinderException;import javax.naming.InitialContext;import javax.naming.NamingException;/** * @author pc * * TODO 要更改此生成的类型注释的模板,请转至 * 窗口 - 首选项 - Java - 代码样式 - 代码模板 */public class CMPClient3 { private javamxj.ejb.cmp.UserManagementHome getHome() throws NamingException {  return (javamxj.ejb.cmp.UserManagementHome) getContext().lookup(    javamxj.ejb.cmp.UserManagementHome.JNDI_NAME); } private InitialContext getContext() throws NamingException {  Hashtable props = new Hashtable();  props.put(InitialContext.INITIAL_CONTEXT_FACTORY,    "org.jnp.interfaces.NamingContextFactory");  props.put(InitialContext.PROVIDER_URL, "jnp://127.0.0.1:1099");  // This establishes the security for authorization/authentication  // props.put(InitialContext.SECURITY_PRINCIPAL,"username");  // props.put(InitialContext.SECURITY_CREDENTIALS,"password");  InitialContext initialContext = new InitialContext(props);  return initialContext; } public void testBean() {  try {   javamxj.ejb.cmp.UserManagement userMgmt = getHome().create();      createUsers(userMgmt);   System.out.println("显示所有权限");   printList(userMgmt.getRoles());      System.out.println("给用户wangyi@aaa.com增加权限 ");   userMgmt.addRole("wangyi@aaa.com", "manager");   userMgmt.addRole("wangyi@aaa.com", "user");      System.out.println("给用户javamxj增加权限 ");   userMgmt.addRole("javamxj@yahoo.com.cn", "admin");   userMgmt.addRole("javamxj@yahoo.com.cn", "user");   System.out.println("显示javamxj拥有的权限");   printList(userMgmt.getUserRole("javamxj@yahoo.com.cn"));  } catch (RemoteException e) {   e.printStackTrace();  } catch (CreateException e) {   e.printStackTrace();  } catch (NamingException e) {   e.printStackTrace();  } catch (FinderException e) {   e.printStackTrace();  } }     //  创建用户 public static void createUsers(UserManagement userMgmt)   throws RemoteException, CreateException {  System.out.println("向Role表中添加数据");  userMgmt.createRole("admin", "系统管理员");  userMgmt.createRole("manager", "内容管理员");  userMgmt.createRole("user", "普通用户");  userMgmt.createRole("guest", "来宾用户"); }  //  输出ArrayList private static void printList(ArrayList list) {  Iterator i = list.iterator();  while (i.hasNext()) {   Object details = (Object) i.next();   System.out.println(details.toString());  }  System.out.println(""); } public static void main(String[] args) {  CMPClient3 test = new CMPClient3();  test.testBean(); }}
 
 
 
3. 运行客户端
·控制台输出:
 
·数据库中相对应的表的改变: