【问题标题】:Call webservice from sql stored procedure从 sql 存储过程调用 webservice
【发布时间】:2014-03-11 08:33:52
【问题描述】:

我想从我的存储过程中调用一个网络服务并获得一个 XML 应答。我真的不知道该怎么做,因为我以前没有做过这样的事情。

这是我的存储过程的样子:

   USE [master]
GO
/****** Object:  StoredProcedure [dbo].[webServiceCall]    Script Date: 3/11/2014     9:12:49 AM ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
-- =============================================
-- Author:      <Author,,Name>
-- Create date: <Create Date,,>
-- Description: <Description,,>
-- =============================================
ALTER PROCEDURE [dbo].[webServiceCall] 
    -- Add the parameters for the stored procedure here
    @personnr varchar (20),
    @username varchar (20),
    @password varchar (20)

AS
 DECLARE @obj INT
 DECLARE @ValorDeRegreso INT
 DECLARE @hr INT
 DECLARE @src varchar(255)
 DECLARE @desc varchar (255)
 DECLARE @srv varchar (200)
 DECLARE @response varchar (8000)



SET @srv = 'http://..../nasherpopman/PopManWebService.asmx?op=GetPerson&personnumber=' + @personnr +'&username=' + @username + '&password=' + @password +''
EXEC sp_OACreate 'MSXML2.ServerXMLHttp', @obj OUT
EXEC sp_OAMethod @obj, 'open', NULL, 'POST', @srv, false
EXEC sp_OAMethod @obj, 'send'
EXEC sp_OAGetProperty @obj, 'responseText', @response out
SELECT @response [response]
EXEC sp_OADestroy @obj
RETURN

现在我收到此错误:服务器无法处理请求。 ---> 缺少根元素

我只是不知道该怎么做,或者我在这里做错了什么。

如果我尝试运行 url,我会得到这个:

GetPerson

Test

The test form is only available for requests from the local machine.
SOAP 1.1

The following is a sample SOAP 1.1 request and response. The placeholders shown need to     be replaced with actual values.

POST /nasherpopman/PopManWebService.asmx HTTP/1.1
Host: .....
Content-Type: text/xml; charset=utf-8
Content-Length: length
SOAPAction: "http://tempuri.org/GetPerson"

<?xml version="1.0" encoding="utf-8"?>
<soap:Envelope xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"     xmlns:xsd="http://www.w3.org/2001/XMLSchema"     xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/">
  <soap:Body>
    <GetPerson xmlns="http://tempuri.org/">
      <personnumber>string</personnumber>
      <username>string</username>
      <password>string</password>
    </GetPerson>
  </soap:Body>
</soap:Envelope>
HTTP/1.1 200 OK
Content-Type: text/xml; charset=utf-8
Content-Length: length

<?xml version="1.0" encoding="utf-8"?>
<soap:Envelope xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"     xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/">
  <soap:Body>
    <GetPersonResponse xmlns="http://tempuri.org/">
      <GetPersonResult>

      <personResult>string</personResult>
    </GetPersonResponse>
  </soap:Body>
</soap:Envelope>

【问题讨论】:

  • 您使用的是什么版本的 SQL Server?
  • 您是否尝试过将该方法调用直接粘贴到浏览器中?您是否仍然收到“缺少根元素”错误?
  • 是的,它没有给我错误,但也没有给我答案。
  • 给我们一个webservice返回的例子。
  • @MikkaRin 我刚刚编辑了上面的返回。虽然它不是真正的回报,更像是服务的构建方式

标签: sql web-services stored-procedures sql-server-2012


【解决方案1】:

你需要做两件事:

  1. 您的网址必须类似于:'http://79.171.249.41/nasherpopman/PopManWebService.asmx/GetPerson?personnumber=' + @personnr +'&...
  2. 然后您应该使用您的 Web 服务配置文件启用 POST 和 GET 协议。

【讨论】:

    【解决方案2】:
    USE [CalculateDistance]
    GO
    /****** Object:  StoredProcedure [dbo].[CalculateDistence]    Script Date: 12/1/2014 12:49:42 PM ******/
    SET ANSI_NULLS ON
    GO
    SET QUOTED_IDENTIFIER ON
    GO
    -- =============================================
    -- Author:      <Author,,Rajay Sachdeva>
    -- Create date: <Create 25/11/2014,,>
    -- Description: <Description,,>
    -- =============================================
    ALTER PROCEDURE [dbo].[CalculateDistence] --'','','','37064','','','','78701',''
    (
    @ToAddress varchar(100) =null,
    @ToCity varchar(100)=null,
    @ToState varchar(100)=null,
    @ToPostCode varchar(100)=null,
    @FromAddress varchar(100)=null,
    @FromCity varchar(100)=null,
    @FromState varchar(100)=null,
    @FromPostCode varchar(100)=null,
    @DistanceInKilometers varchar(100) output
    )
    AS
    
         Declare @Object as Int;
    Declare @ResponseText as Varchar(8000);
    Declare @serviceUrl as varchar(500)
      set @serviceUrl = 'http://maps.googleapis.com/maps/api/distancematrix/xml?origins=' +@ToAddress+@ToCity+@ToState+@ToPostCode+
       '&destinations=' +@FromAddress+@FromCity+@FromState+ @FromPostCode +'&mode=driving&language=en-EN&units=metric;'
    Exec sp_OACreate 'MSXML2.XMLHTTP', @Object OUT;
    Exec sp_OAMethod @Object, 'open', NULL, 'get',
                    @serviceUrl, --Your Web Service Url (invoked)
                     'false'
    Exec sp_OAMethod @Object, 'send'
    Exec sp_OAMethod @Object, 'responseText', @ResponseText OUTPUT
    
    Declare @Response as XML
    
    --Select @ResponseText as XMLList
    
    SET @Response = CAST(@ResponseText AS XML);
    
      Declare @Status as varchar(20)
       Declare @Distance as varchar(20)
    
    
      set @Status= @Response.value('(DistanceMatrixResponse/row/element/status)[1]', 'varchar(20)') 
      print @Status
      if(@Status='ZERO_RESULTS')
    
       Begin
    
                         set @Distance=@Status
       End
       else
    
       Begin
       set @Distance=@Response.value('(DistanceMatrixResponse/row/element/distance/text)[1]', 'varchar(20)') 
       End
      --Select @Response.value('(DistanceMatrixResponse/row/element/distance/text)[1]', 'varchar(10)') as Distance 
      select @Distance as Distance
    Exec sp_OADestroy @Object
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2012-02-10
      • 2019-05-11
      • 2014-03-30
      • 2015-05-08
      • 2021-05-26
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多