zoukankan      html  css  js  c++  java
  • sql server 利用存储过程http请求调用URL链接访问方法

    sp_configure 'show advanced options', 1;
    GO
    RECONFIGURE;
    GO
    sp_configure 'Ole Automation Procedures', 1;
    GO
    RECONFIGURE;
    GO
    EXEC sp_configure 'Ole Automation Procedures';
    GO

    开启权限配置

    DECLARE    @return_value int,
            @status int
    
    EXEC    @return_value = [dbo].[P_HttpRequestData]
            @URL = N'https://test.GoldApi.com/Api/GetGoldSales',
            @status = @status OUTPUT
    
    SELECT    @status as N'@status'

    调用存储

    USE [Test]
    GO
    
    SET ANSI_NULLS ON
    GO
    SET QUOTED_IDENTIFIER ON
    GO
    ALTER PROCEDURE [dbo].[P_GetGoldSales] 
    AS
    set nocount on               
    set transaction isolation level read uncommitted               
    set xact_abort on 
    
    exec [P_HttpRequestData] 'https://test.GoldApi.com/Api/GetGoldSales'

    存储调用存储

    USE [Test]
    GO
    SET ANSI_NULLS ON
    GO
    SET QUOTED_IDENTIFIER ON
    GO
    ALTER PROCEDURE [dbo].[P_HttpRequestData]

    ( @URL varchar(500), @status int=0 OUT,
    @returnText nvarchar(2000)='' OUT )
    AS BEGIN DECLARE @object int,--声明变量 @errSrc int --声明变量 /*初始化*/ EXEC @status = SP_OACreate 'Msxml2.ServerXMLHTTP.3.0', @object OUT; IF @status <> 0 BEGIN EXEC SP_OAGetErrorInfo @object, @errSrc OUT RETURN END /*创建链接*/ EXEC @status= SP_OAMethod @object,'open',NULL,'GET',@URL IF @status <> 0 BEGIN EXEC SP_OAGetErrorInfo @object, @errSrc OUT RETURN END EXEC @status=SP_OAMethod @object,'setRequestHeader','Content-Type','application/x-www-form-urlencoded' /*发起请求信息*/ EXEC @status= SP_OAMethod @object,'send',NULL IF @status <> 0 BEGIN EXEC SP_OAGetErrorInfo @object, @errSrc OUT RETURN END
    /*获取返回*/  
      EXEC @status= SP_OAGetProperty @object,'responseText',@returnText OUT
       IF @status <> 0   
    BEGIN   
    EXEC SP_OAGetErrorInfo @object, @errSrc OUT  
      RETURN
       END
    END;

     创建http请求的存储过程

     

    访问URL地址的 API控制器中创建方法

     public void GetGoldSales(DataRequest<int> request, DataResponse<ResultModel> response)
            {
                var result = new ResultModel();
                result.Status = ResultStatus.Success;
                result.Message = "获取信息成功!";
                try
                {
    var Goldno =string.Empty();
    var List = GetList(request.ObjectData); if (List.Count > 0) {foreach (var item in List) { Goldno+= item + " "; } if (Goldno!=null) { var str = $"货物上架的销售价格异常 异常货品编号: {Goldno}请及紧急查看并修复!"; SendErrorMsg(str); } } } catch (Exception ex) { result.Status = ResultStatus.Fail; result.Message = "获取销售价格信息失败!" + ex.Message; } response.ObjectData = result; }
  • 相关阅读:
    hdu5514 非2的次幂容斥原理
    「NOIP2015」斗地主
    「NOIP2009」靶形数独
    「CF521D」Shop
    「HNOI2015」菜肴制作
    「NOIP2011」观光公交
    「NOI2015」荷马史诗
    「JSOI2007」建筑抢修
    「CF161B」Discounts
    叠罗汉
  • 原文地址:https://www.cnblogs.com/Warmsunshine/p/12016826.html
Copyright © 2011-2022 走看看