测试环境:
服务器系统:Win 2003
工具: Soap Toolkit3.0
开发工具:vs 2010
新建一个WebService 工程
namespace WebApplication1 { /// <summary> /// WebService1 的摘要说明 /// </summary> [WebService(Namespace = "http://tempuri.org/",Name="TS")]//注意这里的“TS”,他才是webservice的名字,而不是WebService1 [WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)] [System.ComponentModel.ToolBoxItem(false)] // 若要允许使用 ASP.NET AJAX 从脚本中调用此 Web 服务,请取消对下行的注释。 [System.Web.Script.Services.ScriptService] public class WebService1 : System.Web.Services.WebService { [WebMethod(BufferResponse = false)] public string InitData() { return "这是一个测试"; } } }
将webservice发布,地址:http://IP地址/vbweb1/
exec sp_configure 'show advanced options',1 ;
reconfigure
sp_configure 'Ole Automation Procedures',1;/*执行该语句时,报错:“配置选项 'Ole Automation Procedures' 不存在,也可能是高级选项。”,但是对于本次测试并没有什么影响。*/reconfigure SET QUOTED_IDENTIFIER ON GO SET ANSI_NULLS ON GO Create procedure sp_WebServiceTest as declare @Hr int,@Object int declare @RtnMsg nvarchar(100) set @Hr = 0 set @Object = 0 set @RtnMsg = '' exec @Hr=sp_OACreate 'MSSOAP.soapClient30',@Object out /*这里是MSSOAP.soapClient30,因为我的系统win2003,如果用MSSOAP.soapClient,执行存储过程会报错;如果winxp系统,两个都可以用*/ exec @Hr=sp_OAMethod @Object,'MSSoapinit',NULL,'http://IP地址/vbweb1/WebService1.asmx?wsdl','TS' /*看到了吗?这里是TS。*/ exec @Hr=Sp_OAMethod @Object,'InitData',@RtnMsg out if @Hr <> 0 begin print '1' Exec Sp_OAGetErrorInfo @Object select @Object end else begin print '2' Select @RtnMsg end exec @Hr=sp_OADestroy @Object GO SET QUOTED_IDENTIFIER OFF GO SET ANSI_NULLS ON GO
执行存储过程。
sp_WebServiceTest
等到的结果
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。