今天老外给了个如标题所示的变态需求。
我找了很长时间才找到解决方法,留下以下笔记。
存储过程中调用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
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。