当前位置: 移动技术网 > IT编程>数据库>MSSQL > SQL执行WebService

SQL执行WebService

2019年03月24日  | 移动技术网IT编程  | 我要评论

光荣日pdf,杜丰生,灵宝车祸

写了一个钉钉发送消息的类, 要发送用友等审核单据信息, 

模式: 钉钉发消息功能在webservice中, 用友消息列表中有新消息时,采用触发器执行webservice. 

在测试中 ,功能正常 ,但将在汉字发送到手机端后,显示乱码. 

其实这种模式不合理, 这个乱码问题也不解决了.下面是触发器中的代码:

use [ufdata_001_2016]
go
/****** object:  storedprocedure [dbo].[richen_message_send]    script date: 11/30/2018 08:03:51 ******/
set ansi_nulls on
go
set quoted_identifier on
go
-- =============================================
-- author:        <李孝徽>
-- create date: <2018-11-05>
-- description:    <单据在提交审批时,调用webservice向钉钉发送通知消息
--               在传入参数时,需要用户id和消息内容 ,最后没使用原因:读数据库发出去消息到钉钉时中文乱码.    >
-- =============================================
alter procedure [dbo].[richen_message_send]
    @userid varchar(30),   
    @content varchar(200)
as

begin
    set nocount on;

    declare @serviceurl nvarchar(1000) 
    declare @urladdress nvarchar(100)
 
    --webservice地址:以http开头,结尾带斜杠
    set @urladdress = 'http://192.168.0.7/richen_ws/dd_ws.asmx/'
 
    declare @funname nvarchar(30)--webservice中调用的方法名
    set @funname = 'send_dd'   
 
    --以下参数对应webservice中参数的[参数名]
    declare @p1  nvarchar(30),@p2  nvarchar(30)
    set @p1='userid'
    set @p2='content'
  
    --参数赋值
    declare @p1_value nvarchar(30),@p2_value  nvarchar(200)
    set @p1_value=@userid
    set @p2_value=@content
    set @serviceurl = @urladdress + @funname  + '?' + @p1 +'='+ @p1_value +'&' + @p2 + '=' +@p2_value 
 
    --select  @serviceurl --调试时查看拼接结果
 
    ----访问地址执行获取结果
    declare @object as int
    declare @responsetext as nvarchar(4000)                   
    exec sp_oacreate 'msxml2.xmlhttp', @object out;
    exec sp_oamethod @object, 'open', null, 'get',@serviceurl,'false'
    exec sp_oamethod @object, 'send'
    exec sp_oamethod @object, 'responsetext', @responsetext output
         
    --select @responsetext     --调试时查看返回参数 
    exec sp_oadestroy @object

end

 

 

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网