加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

存储过程中调用webservice

发布时间:2020-12-17 01:20:32 所属栏目:安全 来源:网络整理
导读:今天老外给了个如标题所示的变态需求。 我找了很长时间才找到解决方法,留下以下笔记。 存储过程中调用webservice其实是在数据库中利用系统函数调用OLE. 1.查找webservice api 可得到MSSOAP.SoapClient。 2.查找API 接口可得到mssoapinit 方法。 3.查找数据

今天老外给了个如标题所示的变态需求。

我找了很长时间才找到解决方法,留下以下笔记。

存储过程中调用webservice其实是在数据库中利用系统函数调用OLE.

1.查找webservice api 可得到MSSOAP.SoapClient。

2.查找API 接口可得到mssoapinit 方法。

3.查找数据库中执行OLE函数sp_OACreate、sp_OAMethod、sp_OADestroy。

到这里基本就完成了,下面是完整的存储过程。

   
   
-- set SoapClient to be work
sp_configure ' Ole Automation Procedures ' , 1
reconfigure
go


DECLARE @object int
DECLARE @hr int
DECLARE @result int
DECLARE @objectResult nvarchar ( 255 )

-- sp_OACreate see more. http://msdn.microsoft.com/en-in/library/ms189763.aspx
EXEC @hr = sp_OACreate ' MSSOAP.SoapClient ' , @object OUT
EXEC @hr = sp_OAMethod @object , ' mssoapinit ' , null , ' http://localhost:52607/WebService1.asmx?WSDL ' , ' WebService1 '
EXEC @hr = sp_OAMethod @object , ' HelloWorld ' , @objectResult OUT

print @hr

IF @hr <> 0
BEGIN
EXEC sp_OAGetErrorInfo @object
print @object
END
ELSE
BEGIN
print @objectResult
end
EXEC @hr = sp_OADestroy @object
GO
http://www.cnblogs.com/chuifeng/archive/2011/03/24/1994095.html

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读