`
agileai
  • 浏览: 55922 次
  • 性别: Icon_minigender_1
  • 来自: 沈阳
社区版块
存档分类
最新评论

ORACLE存储过程调用Web Service

阅读更多

1. 概述

  最近在ESB项目中,客户在各个系统之间的服务调用大多都是在oracle存储过程中进行的,本文就oracle存储过程调用web service来进行说明。其他主流数据库,比如mysqlsql 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 BUSESB),在数通畅联软件的产品家族中应用集成平台命名为AEAI ESB

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

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

UTL_HTTPoracle中自带的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

分享到:
评论

相关推荐

    亮剑.NET深入体验与实战精要2

    7.6.2 通过Microsoft.XMLDOM调用Web Service 291 7.6.3 XMLHTTP POST调用Web Service 293 7.6.4 SOAP调用Web Service 293 7.7 WinForm如何调用Web Service 295 7.7.1 .NET的WinForm调用Web Service 295 7.7.2 手动...

    亮剑.NET深入体验与实战精要3

    7.6.2 通过Microsoft.XMLDOM调用Web Service 291 7.6.3 XMLHTTP POST调用Web Service 293 7.6.4 SOAP调用Web Service 293 7.7 WinForm如何调用Web Service 295 7.7.1 .NET的WinForm调用Web Service 295 7.7.2 手动...

    asp.net知识库

    发布Oracle存储过程包c#代码生成工具(CodeRobot) New Folder XCodeFactory3.0完全攻略--序 XCodeFactory3.0完全攻略--基本思想 XCodeFactory3.0完全攻略--简单示例 XCodeFactory3.0完全攻略--IDBAccesser ...

    php网络开发完全手册

    16.3.2 存储过程的创建与调用 264 16.3.3 存储过程的参数 265 16.3.4 复合语句 267 16.3.5 变量 268 16.3.6 条件语句 269 16.3.7 循环语句 271 16.3.8 游标 273 16.3.9 存储过程的删除 275 16.4 触发器的设计 275 ...

    超级有影响力霸气的Java面试题大全文档

     Servlet被服务器实例化后,容器运行其init方法,请求到达时运行其service方法,service方法自动派遣运行与请求对应的doXXX方法(doGet,doPost)等,当服务器决定将实例销毁的时候调用其destroy方法。 与cgi的区别...

    ssh(structs,spring,hibernate)框架中的上传下载

     文件数据存储在Blob类型的FILE_CONTENT表字段上,在Spring中采用OracleLobHandler来处理Lob字段(包括Clob和Blob),由于在程序中不需要引用到oracle数据驱动程序的具体类且屏蔽了不同数据库处理Lob字段方法上的...

    java 面试题 总结

    Servlet被服务器实例化后,容器运行其init方法,请求到达时运行其service方法,service方法自动派遣运行与请求对应的doXXX方法(doGet,doPost)等,当服务器决定将实例销毁的时候调用其destroy方法。 与cgi的区别...

    千方百计笔试题大全

    209、WEB SERVICE名词解释。JSWDL开发包的介绍。JAXP、JAXM的解释。SOAP、UDDI,WSDL解释。 52 210、STRUTS的应用(如STRUTS架构) 52 211、开发中都用到了那些设计模式?用在什么场合? 52 212、UML方面 52 213、如何...

    java面试宝典

    209、WEB SERVICE名词解释。JSWDL开发包的介绍。JAXP、JAXM的解释。SOAP、UDDI,WSDL解释。 52 210、STRUTS的应用(如STRUTS架构) 52 211、开发中都用到了那些设计模式?用在什么场合? 52 212、UML方面 52 213、如何...

    Spring中文帮助文档

    使用SimpleJdbcCall调用存储过程 11.5.6. 声明SimpleJdbcCall使用的参数 11.5.7. 如何定义SqlParameters 11.5.8. 使用SimpleJdbcCall调用内置函数 11.5.9. 使用SimpleJdbcCall返回的ResultSet/REF Cursor 11.6...

    C#.net_经典编程例子400个

    151 实例106 使用Timer组件实现奥运倒计时 152 3.8 ServiceController组件 154 实例107 使用ServiceController组件控制计算机的服务 154 3.9 ImageList组件 156 实例108 使用ImageList组件...

    Spring API

    使用SimpleJdbcCall调用存储过程 11.5.6. 声明SimpleJdbcCall使用的参数 11.5.7. 如何定义SqlParameters 11.5.8. 使用SimpleJdbcCall调用内置函数 11.5.9. 使用SimpleJdbcCall返回的ResultSet/REF Cursor 11.6...

    Java面试宝典2010版

    22、用JDBC如何调用存储过程 23、JDBC中的PreparedStatement相比Statement的好处 24. 写一个用jdbc连接并访问oracle数据的程序代码 25、Class.forName的作用?为什么要用? 26、大数据量下的分页解决方法。 27、用...

    最新Java面试宝典pdf版

    22、用JDBC如何调用存储过程 109 23、JDBC中的PreparedStatement相比Statement的好处 110 24. 写一个用jdbc连接并访问oracle数据的程序代码 111 25、Class.forName的作用?为什么要用? 111 26、大数据量下的分页解决...

    Java面试笔试资料大全

    22、用JDBC如何调用存储过程 109 23、JDBC中的PreparedStatement相比Statement的好处 110 24. 写一个用jdbc连接并访问oracle数据的程序代码 111 25、Class.forName的作用?为什么要用? 111 26、大数据量下的分页解决...

    spring security 参考手册中文版

    40.3.5 Oracle数据库 280 41.安全命名空间 282 41.1 Web应用程序安全性 282 41.1.1 &lt;debug&gt; 282 41.1.2 &lt;http&gt; 282 属性 283 的子元素 285 41.1.3 &lt;access-denied-handler&gt; 286 的父元素 286 属性 286 41.1.4 &lt;cors&gt;...

Global site tag (gtag.js) - Google Analytics