Oracle应用处事器实现Java CORBA
副标题#e#
摘要:本文通过一个JCORBA应用实例,先容了JCORBA的特点和如安在Oracle 应用处事器中陈设Java CORBA构件。
要害词:Oracle,CORBA,JCORBA,构件,Java
Internet的迅速成长改变了传统的信息交换方法和企业的运行方法,它已经成为很多新兴财富如电子商务、自助处事、网上购物和在线生意业务的前言。越来越多的企业通过Internet构筑起本身企业的信息应用平台,而JAVA语言以其易用性、跨平台性、面向工具性等诸多利益,正跟着这股潮水成为面向企业应用和Internet应用的风行网络计较语言。很多企业正在将他们的贸易应用如电子商务用JAVA来实现,为了适应这种需求,Oracle公司推出其应用处事器产物OAS 4.0(Oracle Application Server Version 4.0),它将Java虚拟机(Virtual Machine)内置于 OAS4.0中,回收称为Java加快器的自然编译要领,将Java库措施先编译为尺度的C代码,再将C代码在差异的CPU和操纵系统的平台长举办编译,生成共享库供Java措施挪用,这种方法大大提高了Java措施的执行速度。
在OAS4.0中,Java应用有多种实现形式,个中以JCORBA(Java CORBA, 简写为JCO)以其机动的客户端挪用,切合CORBA 2.0而广受存眷,同其它的一些CORBA实现平台一样,JCORBA构件在OAS 4.0中实现时,也融入了 Oracle一些自有的特点,下面通过先容JCORBA应用实例"myStack"的开拓进程,向各人先容JCORBA的特点、开拓和利用进程。
一、JCORBA开拓东西
开拓JCORBA,你可以利用任何支持JAVA 1.1.4或今后版本的JAVA开拓平台举办开拓,如Oracle 公司Jdeveloper、SUN公司的JDK、BORLAND 公司的Jbuilder等。在本实例中我们利用 SUN 公司的JDK 1.1.5。
二、成立开拓情况文件目次
在成立JCORBA应用以前,发起成立牢靠名目标目次布局,这样有利于对整个JCORBA应用举办打点,图1 的目次布局已指明白实例中各文件的相应位置,相应的文件在今后的事情不绝插手。
#p#副标题#e#
三、成立方针应用措施
方针应用措施包罗一个类,其类名为ServerStack,它能实现简朴的栈操纵,这个类可实现如下四个要领。
setStackSize() 配置栈的长度
getStackSize() 获取栈的长度
push() 压栈
pop() 从栈中弹出数据
在这个类中,还提供了有关生命期的处理惩罚。
ServerStack.java源代码如下:
package myStack;
import oracle.oas.jco.*;
import java.util.Properties;
public class ServerStack implements Lifecycle
{
private int stackSize = 0;
private String stackElements[];
private int top = -1;
private ObjectManager mgr = null;
private Logger logger = null;
public void jcoCreate()
{
mgr = ObjectManager.getObjectManager(this);
logger = mgr.getLogger();
logger.setSeverity(Logger.LOG_SEVERITY_DEBUG);
try {
Properties env = mgr.getEnvironment();
setStackSize(Integer.parseInt(env.getProperty("initialStackSize")));
}
catch (Exception e) {
}
}
public void jcoDestroy() {
}
public void jcoPassivate()
throws NonReusableException
{
throw new NonReusableException();
}
public void jcoActivate() {
}
public int getStackSize()
{
logger.println(" Getting stack size...");
return stackSize;
}
public void setStackSize(int size) throws StackException
{
if (size < 0)
throw new StackException();
logger.println(" Setting stack size to " + size + "...");
top = -1;
stackSize = size;
stackElements = new String[size];
}
public void push(String value) throws StackException
{
if (top == stackSize - 1)
throw new StackException();
logger.println(" Pushing \"" + value + "\" onto the stack...");
stackElements[++top] = value;
}
public String pop() throws StackException
{
if (top == -1)
throw new StackException();
logger.println(" Popping the stack (returning element " + stackElements[top] + ")...");
return stackElements[top--];
}
}
四、成立长途挪用接口
为了使客户端能挪用ServerStack中的要领,必需要有相应的接口措施,在接口措施中,应包括客户端所能挪用的所有要领,接口措施的措施名为ServerStackRemote.java。措施源代码如下:
package myStack;
public interface ServerStackRemote extends oracle.oas.jco.JCORemote
{
public int getStackSize();
public void setStackSize(int size)
throws StackException;
public void push(String value)
throws StackException;
public String pop()
throws StackException;
}
五、成立异常处理惩罚
在ServerStack中,可以或许响应异常处理惩罚,为了处理惩罚异常,体例相应的异常处理惩罚类,其措施名为 StackException.java。措施源代码如下:
package myStack;
public final class StackException extends Exception
{
public StackException()
{
}
}
六、编译JAVA源代码
#p#分页标题#e#
将上面的三个JAVA措施,ServerStack.java, ServerStackRemote.java, StackException.java,复制到第二节所示的目次布局中。在你举办编译前,查抄你的CLASSPATH情况是否包罗如下路径和文件:
$ORAWEB_HOME/jco/lib/jcort.jar
$ORAWEB_HOME/classes/wrbjidl.jar
$ORAWEB_HOME/classes/services.jar
假如用JDK时编译,呼吁行如下:
prompt>cd ..\Stack\src\MyStack
prompt>javac -d .. \Stack\classes_svr\myStack *.java
编译完成。
".."暗示目次"Stack"地址的目次前缀。
七、成立设置文件
JCORBA应用设置文件名必需为JCO.APP,文件中包括应用措施名,长途接口名及其它系统参数的配置值和初始值。其文件内容如下:
[APPLICATION]
name=myStack_JCO
[ServerStack]
className=myStack.ServerStack
remoteInterface=myStack.ServerStackRemote
[ServerStack.ENV]
initialStackSize=20
八、为应用成立JAR文件
JAR文件中将包括所有成立JCORBA应用所必需的文件,Oracle应用处事器打点措施将从中获得成立JCORBA应用所需的所有资料,并将它们安装在应用处事器相应的位置,我们可以运行JDK中的JAR实用措施来举办该项事情。呼吁行如下:
prompt>cd ..\Stack\classes_svr
prompt>jar cvf Server.jar ..\Stack\classes_svr\myStack\*.class META-INF
发生的JAR文件Server.jar在其相应的目次布局中。
九、将JCORBA应用安装到应用处事器中
按OAS4.0打点措施的要求和安装步调,将Server.jar安装到应用处事器中,其整个安装进程相当简朴,但按装时也应留意如下几点。
Application Type: "JCORBA"
Configure Mode select: "From File"
Display Name: "StackApp"
Jar File: "Server.jar"
安装完成今后,如要利用该应用,应启动它。
十、成立客户端应用
JCORBA的客户端可以有多种形式,主要如下:
欣赏器端的 Java Applets
其它的JCORBA应用
Java应用措施
Jweb 插件
LiveHTML插件
Per1插件
正由于有浩瀚的客户措施范例可以挪用JCORBA,大大拓展了JCORBA的应用范畴,提高了JCORBA重用性和利用的利便性。为了实例先容的利便性,我们选择了Java应用措施作为其客户端实例。
客户端Java措施源代码如下:
import oracle.oas.jco.*;
import oracle.oas.jndi.*;
import oracle.oas.jndi.oas.*;
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.net.URL;
import java.util.Hashtable;
import javax.naming.*;
import myStack.ServerStackRemote;
public class StackClient
{
public static void main(String args[])
{
int stackSize;
String buf, stackElement;
int n = 0;
String _host = "localhost";
ServerStackRemote s = null;
try {
String _urlStr = args[0];
if (_urlStr != null) {
URL _contactURL = new URL(_urlStr);
_host = _contactURL.getHost();
int _port = _contactURL.getPort();
if (_port != -1)
_host = _host + ":" + String.valueOf(_port);
}
Hashtable _env = new Hashtable();
_env.put(Context.URL_PKG_PREFIXES, "oracle.oas.jndi");
// Initial Context
Context _initialContext = new InitialContext(_env);
// Lookup
String _name = "oas://" + _host + "/myStack/ServerStack";
s = (ServerStackRemote) _initialContext.lookup(_name);
System.out.println();
System.out.print("Enter server stack size: ");
BufferedReader d = new BufferedReader(
new InputStreamReader(System.in));
buf = d.readLine();
stackSize = Integer.parseInt(buf);
s.setStackSize(stackSize);
System.out.println("---> Server stack size is currently " +
s.getStackSize());
for(n = 0;;n++) {
System.out.print("Enter stack element (RET to quit): ");
stackElement = d.readLine();
if (stackElement.length() == 0)
break;
s.push(stackElement);
}
System.out.println("---> Server stack currently has the following " +
n + " elements:");
System.out.println();
for (int i = n-1; i >= 0; i--)
System.out.println(" " + s.pop());
} // end try
catch (myStack.StackException se) {
System.out.println("Stack exception occurred.");
System.out.println(se);
}
catch (java.io.IOException ioe) {
System.out.println("The following error occurred while trying to read
input.");
System.out.println(ioe);
}
catch (NamingException ne) {
System.out.print("Communication error: ");
System.out.println(ne.getMessage());
ne.printStackTrace();
}
finally {
if (s != null)
s.destroy(); // from JCORemote
}
System.exit(0);
}
}
为了使客户端和处事器成立毗连,还需将ServerStackRemote.class和StackException.class 复制到 ..\Stack\classes_cnt\myStack目次之下。
编译 StackClient.java 为 StackClient.class,并按第七节的方法发生客户端的JAR文件,JDK呼吁行如下:
prompt>javac -d ..\Stack\classes_cnt\myStack StackClient.java
prompt>cd ..\Stack\classes_cnt
prompt>jar cvf client.jar ..\Stack\classes_cnt\myStack\*.class
客户端JAR文件发生完成。
十一、运行客户端措施挪用JCORBA应用
至此,我们终于可以运行我们的JCORBA应用了,呼吁行如下:
prompt> java StackClient http://appservermachine:port
appservermachine:port:运行OAS的呆板名和其运行端口。假如呆板名为Oracle,端标语为80,我们键入如下命今行和其运行实譬喻下:
prompt> java StackClient http://oracle:80
Enter server stack size: 4
—> Server stack size is currently 4
Enter stack element (RET to quit): 1
Enter stack element (RET to quit): 2
Enter stack element (RET to quit): 3
Enter stack element (RET to quit): 4
Enter stack element (RET to quit):
—> Server stack currently has the following 4 elements:
4
3
2
1
十二、竣事语
#p#分页标题#e#
通过对"myStack"应用实例开拓进程的先容,给出了OAS4.0中JCORBA 应用的实现框架。跟着CORBA构件技能的不绝成长,JAVA语言的遍及利用,这方面的应用和研究将会不绝深入。