在SQL Server 2008中通过sp_OAMethod发送SMS的问题

时间:2012-03-31 09:01:54

标签: sql-server

我使用以下给定的过程从SQL Server发送短信。它工作正常,直到昨天晚上。

但是,今天我收到了以下错误: -

  

-2146697212   消息50000,级别16,状态1,过程pr_SendSmsSQL,行61   sp_OAMethod发送失败!

我添加了“sp_OAGetErrorInfo”以了解确切的错误,然后它会在给定的消息下面显示: -

  

错误来源说明
  msxml3.dll无法连接到目标服务器。

请指导如何解决此问题。相同的代码在另一台SQL Server上正常运行。

存储过程代码: -

SET ANSI_NULLS ON
SET QUOTED_IDENTIFIER ON
GO

/* 
Purpose : To send SMS from SQL. 

declare @sResponse as varchar(1000) 
exec pr_SendSmsSQL '1234567891','This Is a Test SMS From SQL Server - Regards, BSethi24','' 
print @sResponse 

*/ 
ALTER Procedure [dbo].[pr_SendSmsSQL] 
@MobileNo varchar(12), 
@smstext as varchar(300), 
@sResponse varchar(1000) 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 
print @hr 
if @hr <> 0 
Raiserror('sp_OACreate Microsoft.XMLHTTP FAILED!', 16, 1) 


set @sUrl='http://122.22.12.12/smsportal/sendsms.aspx?usr=test&pass=test&senderid=BSethi24&mobileno=#MobNo#&messagetext=#Msg#' 


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 @hr 
if @hr <> 0 
Raiserror('sp_OAMethod Open FAILED!', 16, 1) 

EXEC @hr = sp_OAMethod @iReq, 'send' 
select @iReq
print @hr 
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

insert into s_SmsLog (Id,Mobile_No,SMSText,SMSResponse,Created_By,Created_Date,Modified_By,Modified_Date) 
values(0,@MobileNo,@smstext,@sResponse,'System',GETDATE(),null,null) 
End 

1 个答案:

答案 0 :(得分:0)

存储过程应该只写入队列表。 外部应用程序应该从那里通过存储过程管理进程。

如果要求证明更具可扩展性的解决方案,请考虑使用Service Broker。