Oracle应用处事器实现Java CORBA
当前位置:以往代写 > JAVA 教程 >Oracle应用处事器实现Java CORBA
2019-06-14

Oracle应用处事器实现Java CORBA

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 的目次布局已指明白实例中各文件的相应位置,相应的文件在今后的事情不绝插手。

Oracle应用办事器实现Java CORBA


#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--];
}
}

#p#副标题#e#

四、成立长途挪用接口

为了使客户端能挪用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

#p#副标题#e#

八、为应用成立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"

安装完成今后,如要利用该应用,应启动它。

#p#副标题#e#

十、成立客户端应用

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文件发生完成。

#p#副标题#e#

十一、运行客户端措施挪用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语言的遍及利用,这方面的应用和研究将会不绝深入。

    关键字:

在线提交作业