ORACLE存储过程调用Web Service

1. 概述

  最近在ESB项目中,客户在各个系统之间的服务调用大多都是在oracle存储过程中进行的,本文就oracle存储过程调用web service来进行说明。其他主流数据库,比如mysql和sql service,调用web service的方法这里就不做介绍了,本文主要用来介绍oracle存储过程调用Web Service的方法。

  众所周知,在Web Service通过HTTP协议发送请求和接收结果时,发送的请求内容和结果内容都采用XML格式封装,并增加了一些特定的HTTP消息头,以说明HTTP消息的内容格式,这些特定的HTTP消息头和XML内容格式就是SOAP协议。SOAP协议是基于HTTP协议的,两者的关系就好比高速公路是基于普通公路改造的,在一条公路上加上隔离栏后就成了高速公路。

  同理,在oracle的存储过程中能不能也通过创建XML格式的报文+HTTP协议来调用Web Service呢?答案是肯定的,在ORACLE中有一个名叫UTL_HTTP的工具包,我们可以通过这个工具包来实现存储过程调用Web Service。

  上文提到的AEAI ESB是数通畅联的核心产品之一,可以实现WEB服务开发和WEB服务注册等功能,本文的接口样例,本考虑使用ESB创建的WEB服务,但是由于涉及到的需要介绍的内容和本文主题太远,所以采用了AEAI DP开发平台自带的Web服务样例来说明。有对AEAI ESB感兴趣的读者可以通过本文最后的相关链接查找了解。

2. 预期读者

  • 数通畅联新员工
  • 广大技术爱好者

3. 环境信息

操作系统:Windows7

Oracle: 版本为oracle11g

Mysql版本为mysql5.1

Jdk:  jdk1.6.0_10

4. 名词解释

AEAI ESB:应用集成平台主要作为企业信息系统的“龙骨”来集成各业务系统,一般称之为企业服务总线(Enterprise Service BUS,ESB),在数通畅联软件的产品家族中应用集成平台命名为AEAI ESB。

AEAI DPAEAI DP应用开发平台专门用于开发MIS类的Java Web应用,也称Miscdp(Misc Develope Platform)综合应用开发平台。 AEAI DP应用开发平台在数通畅联软件产品家族中也作为扩展开发的支撑工具,比如:为AEAI Portal门户平台扩展开发Portlet组件、Web Service和Http Service;为AEAI BPM流程集成平台扩展开发业务流程表单及功能等。

存储过程:大型数据库系统中,一组为了完成特定功能的SQL 语句集,存储在数据库中,经过第一次编译后再次调用不需要再次编译,用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。

UTL_HTTP:oracle中自带的HTTP协议工具包,可以用来发送post请求。

PL/SQL Developer:一个集成开发环境,由Allround Automations公司开发,专门面向Oracle数据库存储的程序单元的开发

5. 操作步骤

5.1 创建样例接口

  使用AEAI DP开发平台,创建自带WS服务的应用,如下图:

  选择数据库信息

  部署应用后,查看刚刚创建的应用自带的WS服务

5.2 创建存储过程

5.2.1 基本语法

  以下为创建存储过程的基本语法


CREATE OR REPLACE PROCEDURE存储过程名 ( --定义参数 )

IS

定义变量

BEGIN

开始PL/SQL体

END

说明PL/SQL体结束

5.2.2 创建步骤

1、打开PL/SQL,并打开一个sql窗口

2、将创建存储过程的语句放入其中并执行

  这样一个调用web service的存储过程样例就创建了,以下为详细的样例sql体


--创建存储过程,定义四个参数,入参:userid,code,name;出参:resmark

CREATE OR REPLACE PROCEDURE pro_test_ws(name in varchar2,resmark out varchar2) IS

--定义四个变量,http请求,http返回,请求报文,返回报文

http_req    UTL_HTTP.REQ;

http_Resp   UTL_HTTP.RESP;

request_env VARCHAR2(32767);

l_Replyline VARCHAR2(1000);

BEGIN

--开始pl/sql体

request_env := ‘

<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:demo="http://demo.service.wstest.agileai.com/">

<soapenv:Header/>

<soapenv:Body>

<demo:sayHi>

<!--Optional:-->

<theGirlName>‘|| name ||‘</theGirlName>

</demo:sayHi>

</soapenv:Body>

</soapenv:Envelope>

‘;

--打印请求报文

dbms_output.put_line(request_env);

--请求WS地址

http_req    := UTL_HTTP.

begin_request(‘http://localhost:6060/cam/services/UserSync?wsdl‘,

‘POST‘,

UTL_HTTP.http_version_1_1);

-- 保持连接状态

Utl_Http.Set_Persistent_Conn_Support(http_req, TRUE);

--设置编码

Utl_Http.Set_Header(http_req, ‘Content-Type‘, ‘text/xml;charset=utf-8‘);

Utl_Http.Set_Header(http_req, ‘SOAPAction‘, ‘‘);

--设置字符集

Utl_Http.Set_Body_Charset(http_req, ‘utf-8‘);

--该参数代表我发送的POST报文多长,不可少

Utl_Http.Set_Header(http_req, ‘Content-Length‘, Lengthb(request_env));

Utl_Http.Write_Line(http_req, request_env);

--赋值http返回

http_Resp := Utl_Http.Get_Response(http_req);

--将请求报文赋值给 l_Replyline

Utl_Http.Read_Text(http_Resp, l_Replyline);

dbms_output.put_line(l_Replyline);

--付给存储过程出参

resmark:=l_Replyline;

END pro_test_ws;

5.2.3 关键点说明

  在存储过程中,使用UTL_HTTP工具包调用web服务时,几个关键方法的使用说明

1. 通过设置请求地址、方式、协议版本,得到http请求对象


http_req    := UTL_HTTP.

begin_request(‘ http://localhost:6060/wstest_project/services/HelloWorld?wsdl ‘,

‘POST‘,

UTL_HTTP.http_version_1_1);

2. 设置协议保持连接状态


Utl_Http.Set_Persistent_Conn_Support(http_req, TRUE);

3. 设置请求编码,SOAPAction header的值为空串("")表示SOAP消息的目的地由HTTP请求的URI标识;无值则表示没有指定这条消息的目的地。


Utl_Http.Set_Header(http_req, ‘Content-Type‘, ‘text/xml;charset=utf-8‘);

Utl_Http.Set_Header(http_req, ‘SOAPAction‘, ‘‘);

4. 设置字符集


Utl_Http.Set_Body_Charset(http_req, ‘utf-8‘);

5. 报文长度


Utl_Http.Set_Header(http_req, ‘Content-Length‘, Lengthb(request_env));

6. 调用服务,发送报文


Utl_Http.Write_Line(http_req, request_env);

7. 得到返回体


http_Resp := Utl_Http.Get_Response(http_req);

8. 将返回报文赋值给变量


Utl_Http.Read_Text(http_Resp, l_Replyline);

5.3 调用存储过程

5.3.1 使用PL/SQL Developer测试

1) 选中存储过程的名字,右键选择测试,进入测试页面

2) 添加响应的参数值,F9或者点击按钮开始执行,执行后可以得到看到返回值

3) 切换到DBMS输出页面,可以看到打印的内容

5.3.2 使用sql代码调用


DECLARE

resmark varchar2(1000);

BEGIN

pro_test_ws(‘‘小郑‘,resmark);

DBMS_OUTPUT.PUT_LINE(resmark);

END;

1) 打开sql窗口,执行上面的sql语句

2) 查看输出信息

  1处为存储过程打印的信息,2为调用时打印输出的信息

6. 总结说明

  本文介绍了在oracle存储过程中,使用UTL_HTTP工具包,通过创建请求报文以及使用HTTP协议来调用Web Service,从创建oracle存储过程以及UTL_HTTP相关参数的配置,到通过PL/SQL Developer测试调用以及sql代码进行调用来详细说明。

  附件为存储过程创建sql、调用sql以及接口程序和相关的数据库文件。

7. 相关链接

AEAI DP开发平台/ AEAI ESB集成平台相关介质以及文档资料地址:http://www.agileai.com/portal/website/01/res-share.ptml

文档及代码附件下载http://pan.baidu.com/s/1kVyMVQn

时间: 2024-10-13 04:27:40

ORACLE存储过程调用Web Service的相关文章

存储过程封装web service

作者:卞功鑫  ,转载请保留http://www.cnblogs.com/BinBinGo/p/6959569.html. sql 也可以调用web service 步骤如下: 1 修改配置 sp_configure 'show advanced options', 1; GO RECONFIGURE; GO sp_configure 'Ole Automation Procedures', 1; GO RECONFIGURE; GO 2 把调用过程封装在存储过程中,这是我引用高德地图的事例 C

VB.NET,C#.NET调用Web Service,利用visual studio 的实现方法

在VB.NET调用Web Service提供的服务 技术qq交流群:JavaDream:251572072 下面是一篇文章比较详细,其实具体操作很简单,把Web Service服务地址,利用工具(VS2010),通过添加引用的形式,添加到项目中来就可以应用了. 大家如果这个地方不会操场的话,可以问问我QQ:1606841559 当Web Service已经处于对外提供服务状态,VB.NET就可以通过HTTP"调用"来使用这些服务了.当然前提是要了解Web Service对外提供服务所对

SPServices介绍之三:使用SPSerivces对象调用Web Service

SPServices介绍之三:使用SPSerivces对象调用Web Service 分类: SPSerivces2014-09-21 04:23 304人阅读 评论(0) 收藏 举报 在上一篇文章SPServices介绍之二中,介绍了一些SPServices的基本方法,除了这些方法,SPServices的主要用处是使用Ajax方法调用SharePoint提供的Web Service. 先看一下语法: [javascript] view plaincopy $().SPServices({ op

C#使用SOAP调用Web Service

程序代码 using System;using System.IO;using System.Net;using System.Text; namespace ConsoleApplication1{ class Program    { static void Main(string[] args)        {            //构造soap请求信息            StringBuilder soap = new StringBuilder();            s

php5调用web service

工作中需要用php调用web service接口,对php不熟,上网搜搜,发现关于用php调用web service的文章也不多,不少还是php4里用nusoap这个模块调用的方法,其实php5里已经包含了处理soap的模块,但是资料太少了,上php官网上查帮助,写的不是很容易理解,经过多次实践,终于搞清楚了,php调用web service还是非常简单的.下面用一个例子说明: extension=php_openssl.dll extension=php_soap.dll php.ini 这2

Android调用web Service

---恢复内容开始--- 继总结过web service后,再总结一下android中使用web service. 在android中使用web service需要使用到一个第三方开源的类库——ksoap2.他是一个SOAP Web Service客户端开发包.是android平台上高效.轻量级的SOAP开发包. 使用SOAP需要引入第三方的jar包:ksoap2-android-assembly-2.5.4-jar-with-dependencies.jar.如何加入jar包就不在赘述.下面讲

asp.net调用web service不通过添加web引用的方式怎么调用

创建方法 //动态调用web服务 public static object InvokeWebSer(string url,string @namespace, string classname, string methodname, object[] args) { System.Net.WebClient wc = new System.Net.WebClient(); string URL=string.Empty; if ((url.Substring(url.Length - 5, 5

Android---56---Android应用调用Web Service/号码归属地查询

使用Android应用调用Web Service 需要工具: ksoap2-android 下载地址:http://pan.baidu.com/s/1jGL6b10 build path将ksoap2-android 添加到项目工程中 先将ksoap2-android 包导入 libs目录下,右键build path -> add to build path 点击项目工程名,右键 build path -> configure build path 在ksoap2-android这个包前面打上

基于Web Service的客户端框架搭建一:C#使用Http Post方式传递Json数据字符串调用Web Service

引言 前段时间一直在做一个ERP系统,随着系统功能的完善,客户端(CS模式)变得越来越臃肿.现在想将业务逻辑层以下部分和界面层分离,使用Web Service来做.由于C#中通过直接添加引用的方来调用Web Service的方式不够灵活,故采取手动发送Http请求的方式来调用Web Service.最后选择使用Post方式来调用Web Service,至于安全性和效率暂不考虑.在学习使用的过程,遇到了很多问题,也花了很长时间来解决,网上相关的帖子很少,如果各位在使用的过程中有一些问题难以解决,可