从SQL Server 2014 Issu标识发送SMS

时间:2017-03-18 08:03:52

标签: sql-server sql-server-2008 stored-procedures sms-gateway

我使用以下代码从SQL Server 2014发送短信。它曾经正常工作,但几天后它无法正常工作。我还在另一个SQL Server中执行了以下代码,它运行正常。但由于某些原因在SQL Server 2014中没有工作。我也尝试在浏览器中使用url发送槽,它也可以工作。但有些我如何通过存储过程无法工作。

SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO

--EXEC sp_SendSmsSQL '*****','Today is Saturday',''

ALTER procedure [dbo].[sp_SendSmsSQL] 
    @MobileNo varchar(max), 
    @smstext as varchar(300), 
    @sResponse varchar(8000) OUT 
as 
BEGIN 
   DECLARE @iReq int,@hr int 
   DECLARE @sUrl as varchar(500) 
   DECLARE @errorSource VARCHAR(8000)
   DECLARE @errorDescription VARCHAR(8000) 

   -- Create Object for XMLHTTP 
   EXEC @hr = sp_OACreate 'Microsoft.XMLHTTP', @iReq OUT

   --EXEC @hr = sp_OACreate 'MSXML2.ServerXMLHTTP', @iReq OUT   
   print '*'
   print 'hr : ' + cast(@hr as varchar)

   if @hr <> 0 
    Raiserror('sp_OACreate Microsoft.XMLHTTP FAILED!', 16, 1)

    set @sUrl='****'
    set @sUrl=REPLACE(@sUrl,'#MobNo#',@MobileNo) 
    set @sUrl=REPLACE(@sUrl,'#Msg#',@smstext) 

    print @sUrl 


   -- sms code start 
   EXEC @hr = sp_OAMethod @iReq, 'Open', NULL, 'GET', @sUrl, true 
   print '**'
   print @hr 

   if @hr <> 0 
      Raiserror('sp_OAMethod Open FAILED!', 16, 1) 

   EXEC @hr = sp_OAMethod @iReq, 'Send' 
   select @iReq
   print '***'
   print 'hr : ' + cast(@hr as varchar)

   if @hr <> 0 
   Begin 
       EXEC sp_OAGetErrorInfo @iReq, @errorSource OUTPUT, @errorDescription OUTPUT

       SELECT [Error Source] = @errorSource, [Description] = @errorDescription

       Raiserror('sp_OAMethod Send FAILED!', 16, 1) 
   end 
    else 
    Begin
        EXEC @hr = sp_OAGetProperty @iReq,'responseText', @sResponse OUT 

        print @hr
        print '****'
        print @sresponse


    end

    EXEC @hr=sp_OADestroy @iReq
    print @hr 

    DBCC FREEPROCCACHE
    DBCC DROPCLEANBUFFERS
END

结果

    *
hr : 0
url ='******'
**
0

(1 row(s) affected)
***
hr : 0
-2147483638
****

0
DBCC execution completed. If DBCC printed error messages, contact your system administrator.
DBCC execution completed. If DBCC printed error messages, contact your system administrator.

1 个答案:

答案 0 :(得分:0)

您没有提供SQL Server返回的错误消息,但这听起来像是一个安全问题。 DBCC FREEPROCCACHE需要Alter服务器状态权限。此外,需要启用sp_oa ...方法,并且用户必须有权运行它们(SQL Server blocked access to procedure 'sys.sp_OACreate' of component 'Ole Automation Procedures')。最后,我不确定为什么要在存储过程中运行DBCC命令。 FREEPROCCACHE有局限性,但您可以使用选项(https://msdn.microsoft.com/en-us/library/ms174283.aspx)来调用它。 DROPCLEANBUFFERS真正意味着测试查询性能。如果您的DBCC命令仅用于测试,请从存储过程中删除它们,并在调用存储过程后立即将它们放入。