程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> 關於JAVA >> EJB技術之旅(二)

EJB技術之旅(二)

編輯:關於JAVA

設計實例的深入分析

要求:

本文假設讀者對EJB技術有一定熟悉,對SQL有一定了解就可以了。由於EJB涉及到的技術很多,盡管每次只講述一種技術,但各種技術是相關的,所以希望讀者諒解,因為這樣不是很好組織。

實例背景

數據庫:SQL Server 2000

操作系統:Windows 2000

開發工具:JBuilder 7

EJB服務器:WebLogic 7.0

機器IP地址,10.11.12.58

實例綜述:通過無狀態Session Beans得到容器管理的Entity Beans中的數據,然後把無狀態Session Beans得到的數據給JSP頁面,從而客戶可以看到所要的結果。通過這樣一種過程使得您知道編寫EJB組件是多麼簡單的事情。

准備工作

配置好SQL Server 2000的JDBC驅動(微軟網站有下載,或者用BEA提供的也可以!該例子中用的是微軟的JDBC)、JBuilder 7 + WebLogic 7集成環境,其他的也可以。

開發過程

1.配置JDBC數據源:這個過程包括兩個步驟,首先配置連接池(Connection Pools)。(為什麼采用連接池:開發人員不想編寫Database方面的代碼、更換數據庫系統變得簡單、限制數據庫的連接數量、不需要為每個客戶建立新連接。這種池的概念在J2EE中有很多地方出現了,比如EJB本身)配置的參數如下:

Name: cacd

URL: jdbc:microsoft:sqlserver://10.11.12.58:1433;user=sa;password=cacd;

Driver ClassName: com.microsoft.jdbc.sqlserver.SQLServerDriver

Initial Capacity: 3

Maximum Capacity: 10

其次,配置JDBC數據源,在Tx Data Sources中配置的參數如下:

Name: cacd

JNDI Name: cacd

Pool Name: cacd(要與前面的相匹配!)

(Tx Data Sources與一般的Data Sources 區別何在?讀給讀者思考、討論。)

其中,在URL中,你需要為SQL Server 2000配置一個用戶名sa,密碼為cacd,因為這裡用的是Type 4的JDBC,所以需要將SQL Server 2000的用戶認證修改為:NT+SQL Server 2000混合認證。

2.數據庫的建立:Entity Beans代表了Database中的數據,所以需要數據庫支持,但一般情況下,我們知道,可以根據容器管理的Entity Beans導出SQL DDL。另一方面,可以根據SQL DDL生成容器管理的Entity Beans。兩種方法都可以。比如JBuilder 7兩種方法都提供了。但我想,信息模型(數據庫)的建立在編碼之前就應該存在,所以建議采用第二種辦法。當然有些時候第一種會較為合理些,因為並不是表中所有的字段都會映射到Entity Beans中。該例子中建立了這樣這樣一個Table:

/*===================================================*/
/* Table : techniquespec */
/*===================================================*/
create table techniquespec (
techniqueitem char(100) not null,
units char(10) null,
minvalue decimal(16,6) null,
maxvalue decimal(16,6) null,
types char(1) null,
signon char(1) null,
constraint PK_TECHNIQUESPEC primary key (techniqueitem)
)

其中,開發人員在建表的過程中,不需要手工去寫SQL DDL語句,一般都可以借助於工具進行,比如PowerDesigner、ERWin等工具。用用就會了,不要對工具產生不好的情緒,但前提是你熟悉數據庫理論。

用戶建好Table後,可以填入數據,中文的也可以。

3.容器管理的Entity Beans的開發:JBuilder對EJB開發支持的比較好,提供了圖形化的方式。由於我們已經建立好了Database,前面的techniquespec表,我們可以借助於Import Schema From Database,將SQL DLL引入進來。(由於這裡不能貼出操作圖片,所以只能用文字說明梗概,大家在設計過程中有什麼問題,可以發郵件給我,我盡力而為。)在這個過程中,一定要注意JNDI的名字和數據源中的JNDI要一致。得到SQL DLL後,我們可以根據techniquespec表生成CMP 2.0 Entity Beans,在這裡我們采用LocalHome訪問Entity Beans,為什麼采用?後續文章中都會詳細闡述。現在想返回表techniquespec中列techniqueitem的所有內容。首先,真假一個findByTypes Finder方法,EJB QL語句為:SELECT OBJECT(p) from Techniquespec AS p,其中返回值為Collection。下面給出代碼。

LocalHome接口:

package cacdsystem;
import javax.ejb.*;
import java.util.*;
public interface TechniquespecHome extends javax.ejb.EJBLocalHome
{
  public Techniquespec create(String techniqueitem)
   throws CreateException;
  public Collection findByTypes()
   throws FinderException;
  //添加的Finder方法
  public Techniquespec findByPrimaryKey(String techniqueitem)
   throws FinderException;
}

Local接口:

package cacdsystem;
import javax.ejb.*;
import java.util.*;
import java.math.*;
public interface Techniquespec extends javax.ejb.EJBLocalObject
{
  public String getTechniqueitem();
  public void setUnits(String units);
  public String getUnits();
  public void setMinvalue(BigDecimal minvalue);
  public BigDecimal getMinvalue();
  public void setMaxvalue(BigDecimal maxvalue);
  public BigDecimal getMaxvalue();
  public void setTypes(String types);
  public String getTypes();
  public void setSignon(String signon);
  public String getSignon();}
  bean類:
package cacdsystem;
import javax.ejb.*;
abstract public class TechniquespecBean implements EntityBean
{
  EntityContext entityContext;
  public java.lang.String ejbCreate(java.lang.String techniqueitem)
   throws CreateException
  {
   setTechniqueitem(techniqueitem);
   return null;
  }
 
  public void ejbPostCreate(java.lang.String techniqueitem)
   throws CreateException {}
  public void ejbRemove() throws RemoveException {}
  public abstract void setTechniqueitem(java.lang.String techniqueitem);
  public abstract void setUnits(java.lang.String units);
  public abstract void setMinvalue(java.math.BigDecimal minvalue);
  public abstract void setMaxvalue(java.math.BigDecimal maxvalue);
  public abstract void setTypes(java.lang.String types);
  public abstract void setSignon(java.lang.String signon);
  public abstract java.lang.String getTechniqueitem();
  public abstract java.lang.String getUnits();
  public abstract java.math.BigDecimal getMinvalue();
  public abstract java.math.BigDecimal getMaxvalue();
  public abstract java.lang.String getTypes();
  public abstract java.lang.String getSignon();
  public void ejbLoad(){}
  public void ejbStore(){}
  public void ejbActivate(){}
  public void ejbPassivate(){}
  public void unsetEntityContext()
  {
   this.entityContext = null;
  }
  public void setEntityContext(EntityContext entityContext)
  {
   this.entityContext = entityContext;
  }
}

4.無狀態Session Beans的開發:通過EJB 圖形設計器,生成一個Session Bean,代碼如下。

Home接口:

package cacdsystem;
  import javax.ejb.*;
  import java.util.*;
  import java.rmi.*;
  public interface VocHome extends javax.ejb.EJBHome
  {
   public Voc create() throws CreateException, RemoteException;
  }

Remote接口:

package cacdsystem;
  import javax.ejb.*;
  import java.util.*;
  import java.rmi.*;
  public interface Voc extends javax.ejb.EJBObject
   {
    public Collection getVocTechnique() throws RemoteException;
   }

bean類:

package cacdsystem;
  import javax.ejb.*;
  import java.util.*;
  public class VocBean implements SessionBean
  {
   SessionContext sessionContext;
   TechniquespecHome techniquespecHome;
   public void ejbCreate() throws CreateException {}
   public void ejbRemove() {}
   public void ejbActivate() {}
   public void ejbPassivate() {}
   public void setSessionContext(SessionContext sessionContext)
   {
    this.sessionContext = sessionContext;
    try
    {
     javax.naming.Context context = new javax.naming.InitialContext();
     techniquespecHome = (TechniquespecHome)context.lookup("Techniquespec");
    }
    catch (Exception ex)
    {
     System.out.println("Techniquespecs調用出錯!");
     throw new EJBException(ex);
    }
   }
   public java.util.Collection getVocTechnique()
   {
    /**@todo Complete this method*
    //*** 獲得全部技術需求項函數!*/
    System.out.println("調用getVocTechnique()!");
    java.util.Collection collection = null;
    java.util.List results = new ArrayList();
    try
    {
     collection= techniquespecHome.findByTypes();
     if(collection.size() > 0)
     {
      System.out.println(collection.size());
      Iterator iter = collection.iterator();
      String tempStr = null;
      Techniquespec techniqu = null;
      while(iter.hasNext())
      {
       techniqu = (Techniquespec) iter.next();
       tempStr = techniqu.getTechniqueitem();
       tempStr = charASC.chinTOISO(tempStr);
       results.add(tempStr);
      }
     }
    }
    catch (Exception ex)
    {
     ex.printStackTrace();
     throw new EJBException(ex);
    }
    return results;
   }
  }

說明:

(1)我們在Session Bean中添加了一個商務方法,getVocTechnique(),以獲得techniqueitem中的全部內容。

(2)setSessionContext中,我們完成了EJB的一些初始化工作。(3) charASC.chinTOISO是用於中文轉換的靜態方法,代碼如下:

package cacdsystem;
  public class charASC
  {
   static private String results = null;
   public charASC(){}
   static public String chinTOISO(String temp)
   {
    if(temp == null)
    {
     results = "";
    }
    else
    {
     try
     {
      results = new String(temp.getBytes("ISO-8859-1"),"gb2312");
      results = results.trim();
     }
     catch(Exception ee)
     {
      System.out.println("中文轉換失敗!");
     }
    }
    return results;
   }
  }

5.JSP頁面的開發:針對Session Bean,我編寫了一個JSP頁面。

<%@page contentType="text/html;charset=gb2312"%>
<%@page import="java.text.*" %>
<%@page import="java.util.*"%>
<%@page import="java.sql.*" %>
<%@page import="javax.naming.*" %>
<%@page import="java.lang.*" %>
<%@page import="javax.rmi.PortableRemoteObject" %>
<%@page import="javax.ejb.* "%>
<%@page import="cacdsystem.*"%>
<html>
<head>
<title>產品技術需求提取</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
</head>
<body>
<form id=form name=form1 method=post>
<input type=hidden id=pageFlag name=pageFlag value='input'>
<table cellSpacing=0 cellPadding=0 width="98%" border=0 align=center >
<tr height=30 class=titleFont>
<td><font color='#0058a5'> 您所在位置:產品技術需求提取</font></td>
</tr>
<tr height=1 class=titleFont>
<td></td>
</tr>
</table>
<table width="98%" border="0" bgcolor='#999999' align=center>
<tr>
<td><b> <font color="#ffffff">產品技術需求提取</font></b></td>
</tr>
</table>
<table width="98%" border="1" align=center bgcolor="#f0f0f0" bordercolor='#ffffff' cellspacing=0 cellpadding=0 class=titleFont>
<tr bgcolor='#e0e8f8'>
<td> </td>
</tr>
<%
InitialContext ctx = new InitialContext();
VocHome vocHome =
(VocHome)PortableRemoteObject.narrow(ctx.lookup("Voc"),VocHome.class);
Voc voc = vocHome.create();
Collection collection = voc.getVocTechnique();
if(collection.size() > 0)
{
Iterator iters = collection.iterator();
int i = 0;
while(iters.hasNext())
{
++i;
%>
<tr>
<td><input type='checkbox' name=<%= "select"+i %>
value=<%= i %>><%= (String)iters.next() %><br></td>
</tr>
<%
}
}
%>
<%
voc.remove();
%>
<tr bgcolor='#e0e8f8' align=middle>
<td>
<p align=left></p>
</td>
</tr>
<tr align=middle>
<td>
<input type=submit id=submit1 name=submit1 value="提 交">
<input type=reset id=submit1 name=submit value="重 置">
</td>
</tr>
</table>
</form>
</body>
</html>

6.系統Deploy: 到現在為止,我們實現了Entity Bean、Session Bean、JSP,從而實現了該實例所需要的代碼。為使我們測試代碼的正確性,我們來Deploy到服務器上。首先,由於在Session Bean中引用了Entity Bean,所以需要申明。

<session>
<display-name>Voc</display-name>
<ejb-name>Voc</ejb-name>
<home>cacdsystem.VocHome</home>
<remote>cacdsystem.Voc</remote>
<ejb-class>cacdsystem.VocBean</ejb-class>
<session-type>Stateless</session-type>
<transaction-type>Container</transaction-type>
<ejb-local-ref> //手工添加的配置描述符代碼!
<description />
<ejb-ref-name>Techniquespec</ejb-ref-name>
<ejb-ref-type>Entity</ejb-ref-type>
<local-home>cacdsystem.TechniquespecHome</local-home>
<local>cacdsystem.Techniquespec</local>
<ejb-link>Techniquespec</ejb-link>
</ejb-local-ref>
</session>

其次,需要將EJB的接口文件拷貝到web-inf\classes目錄下。在這裡由於是存在package cacdsystem中,需要把4個接口文件拷貝到web-inf\classes\cacdsystem中。第三,將EJB打包成.jar文件,JBuilder 7可以自動完成,記得要包括charASC.class文件。生成.jar後發布到服務器上可以通過JBuilder 7發布,也可以通過WebLogic提供的Builder工具,或者通過Console發布,或者通過將.jar拷貝到applications目錄即達到發布的目的。

最後,我們也可以通過把整個EJB、JSP打包成.ear文件,JBuilder工具提供了Wizard。

總結

整個過程實現了EJB組件開發,從而對EJB有了一定的認識。接下來的文章中,我會繼續深入講述EJB技術涉及到的技術。謝謝大家看完我的寫文章,也希望大家寫信和我交流。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved