百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 优雅编程 > 正文

Oracle触发器调用webservice说明(oracle触发器调用java)

sinye56 2024-09-27 21:33 4 浏览 0 评论

Oracle触发器调用webservice说明

该文档主要介绍oracle触发器加载java代码,在java代码中调用一个webservice服务接口的测试例子。

1. 测试环境(本测试用例使用的环境)

· Oracle版本:Release 10.2.0.1.0

· Tomcat版本:apache-tomcat-7.0.63

2. Webservice服务器

使用axis2创建一个测试用的webservice服务器。

服务器配置:

1) 把附件中的[axis2.war]拷贝到tomcat路径下的webapps。我的是在C:\apache-tomcat-7.0.63\webapps。启动tomcat,axis2.war会自动解压。

2) 把附件中的[test.aar]文件拷贝到解压后的文件路径axis2\WEB-INF\services下面。我的是在C:\apache-tomcat-7.0.63\webapps\axis2\WEB-INF\services。

3) 这样webservice服务器就配置好了。

说明:test.aar文件就是webservice测试服务器代码编译成的。使用的是axis2 Service Archiver插件编译而成。插件如下:

服务器代码如下:


3. Java代码

Java端代码说明:由于java代码需要加载到oracle中,而oracle10g使用的jdk版本为1.4。因此java端代码只能使用1.4版本的jdk支持的api。此处测试代码用的是axis调用webservice。

说明:下列代码中ulr=?的地址需要自行修改,根据自己tomcat端口调整。

3.1代码如下

文件名为Main.java

import java.rmi.RemoteException;

import javax.activation.DataHandler;

import javax.xml.namespace.QName;

import javax.xml.rpc.ServiceException;

import org.apache.axis.client.Call;

import org.apache.axis.client.Service;

import org.apache.axis.encoding.ser.JAFDataHandlerDeserializerFactory;

import org.apache.axis.encoding.ser.JAFDataHandlerSerializerFactory;

public class Main {

public static void service(String name) {

String url = "http://localhost:8800/axis2/services/test/simpleMethod";

Service service = new Service();

Call call;

String vstr ;


try {

call = (Call) service.createCall();

QName qn = new QName("ns1:DataHandler", "DataHandler");

call.setTargetEndpointAddress(url);

call.setOperationName(new QName("http://test", "simpleMethod"));


call.registerTypeMapping(DataHandler.class, qn,

JAFDataHandlerSerializerFactory.class,

JAFDataHandlerDeserializerFactory.class);


vstr = (String)call.invoke(new Object[] {name});

System.out.println(vstr);


} catch (ServiceException e) {

e.printStackTrace();

} catch (RemoteException e) {

e.printStackTrace();


}

}

}

3.2所需jar包

为了能正常运行上述java代码,需要在oracle中加载两个axis的jar包,分别为:axis.jar,commons-discovery-0.2.jar。

1)将附件中的axis.jar,commons-discovery-0.2.jar两个jar包拷贝到oracle路径..\ sqlj\lib下。我的oracle路径是:F:\oracle\product\10.2.0\db_1\sqlj\lib。根据oracle安装路径自行修改。

2)加载axis.jar,commons-discovery-0.2.jar到oracle中

在cmd窗口中,切换到F:\oracle\product\10.2.0\db_1\sqlj\lib下,运行下列指令:

loadjava -u system/oracle -r -v -f -genmissing -s -grant public axis.jar commons-discovery-0.2.jar

system/oracle:数据库用户名/密码

指令执行完之后,显示:

3)加载java文件到oracle中

在cmd中运行下列指令:

loadjava -r -f -o -user system/oracle@orcl f:\Main.java

4)至此,java文件被成功加载到oracle中了。

4. 存储过程

打开oralce自带的sqlplus工具,创建存储过程并调用java代码。

create or replace procedure service(name varchar2) as language java name 'Main.service(java.lang.String)';

/

如下图:

赋权限:

在sqlplus中用超级管理员登录,给system用户赋权限。

conn /as sysdba

exec dbms_java.grant_permission( 'SYSTEM','SYS:java.lang.RuntimePermission', 'createClassLoader', '' );

commit;

exec dbms_java.grant_permission( 'SYSTEM','SYS:java.lang.RuntimePermission', 'getClassLoader', '' );

commit;

exec dbms_java.grant_permission( 'SYSTEM','SYS:java.net.SocketPermission', 'localhost', 'resolve' );

commit;

exec dbms_java.grant_permission( 'SYSTEM', 'SYS:java.net.SocketPermission', '127.0.0.1:8800', 'connect,resolve' );

commit;

如下图:

5. Oracle触发器

创建一个基于wjq.operator表(我的数据库中的一个表),每行数据有更新的触发器,并调用存储过程,如下:

在sqlplus中执行,用system用户登录:

CREATE OR REPLACE TRIGGER trigger_update

before update

ON wjq.operator

FOR EACH ROW

BEGIN

service('张三');

END ;

/

如下图:

6. 测试

在sqlplus中测试,执行更新语句操作。

wjq.operator中只有两行数据:

执行update wjq.operator set sex='1';时所有的数据都要更新,触发器被执行两次。

执行update wjq.operator set sex='1' where sex ='2';时有一条数据需要被更新,触发器被执行一次。

如下图:

相关推荐

Linux在线安装JDK1.8

首先在服务器pingwww.baidu.com查看是否可以连网然后就可以在线下载一、下载安装JDK1.81、在下载安装的同时做好一些准备工作...

Linux安装JDK,超详细

1、了解RPMRPM是Red-HatPackageManager(RPM软件包管理器)的缩写,这一文件格式名称虽然打上了RedHat的标志,但是其原始设计理念是开放式的,现在包括OpenLinux...

Linux安装jdk1.8(超级详细)

前言最近刚购买了一台阿里云的服务器准备要搭建一个网站,正好将网站的一个完整搭建过程分享给大家!#一、下载jdk1.8首先我们需要去下载linux版本的jdk1.8安装包,我们有两种方式去下载安装...

Linux系统安装JDK教程

下载jdk-8u151-linux-x64.tar.gz下载地址:https://www.oracle.com/technetwork/java/javase/downloads/index.ht...

干货|JDK下载安装与环境变量配置图文教程「超详细」

1.JDK介绍1.1什么是JDK?SUN公司提供了一套Java开发环境,简称JDK(JavaDevelopmentKit),它是整个Java的核心,其中包括Java编译器、Java运行工具、Jav...

Linux下安装jdk1.8

一、安装环境操作系统:CentOSLinuxrelease7.6.1810(Core)JDK版本:1.8二、安装步骤1.下载安装包...

Linux上安装JDK

以CentOS为例。检查是否已安装过jdk。yumlist--installed|grepjdk或者...

Linux系统的一些常用目录以及介绍

根目录(/):“/”目录也称为根目录,位于Linux文件系统目录结构的顶层。在很多系统中,“/”目录是系统中的唯一分区。如果还有其他分区,必须挂载到“/”目录下某个位置。整个目录结构呈树形结构,因此也...

Linux系统目录结构

一、系统目录结构几乎所有的计算机操作系统都是使用目录结构组织文件。具体来说就是在一个目录中存放子目录和文件,而在子目录中又会进一步存放子目录和文件,以此类推形成一个树状的文件结构,由于其结构很像一棵树...

Linux文件查找

在Linux下通常find不很常用的,因为速度慢(find是直接查找硬盘),通常我们都是先使用whereis或者是locate来检查,如果真的找不到了,才以find来搜寻。为什么...

嵌入式linux基本操作之查找文件

对于很多初学者来说都习惯用windows操作系统,对于这个系统来说查找一个文件简直不在话下。而学习嵌入式开发行业之后,发现所用到的是嵌入式Linux操作系统,本想着跟windows类似,结果在操作的时...

linux系统查看软件安装目录的方法

linux系统下怎么查看软件安装的目录?方法1:whereis软件名以查询nginx为例子...

Linux下如何对目录中的文件进行统计

统计目录中的文件数量...

Linux常见文件目录管理命令

touch用于创建空白文件touch文件名称mkdir用于创建空白目录还可以通过参数-p创建递归的目录...

Linux常用查找文件方法总结

一、前言Linux系统提供了多种查找文件的命令,而且每种查找命令都具有其独特的优势,下面详细总结一下常用的几个Linux查找命令。二、which命令查找类型:二进制文件;...

取消回复欢迎 发表评论: