• Sql Server 调用接口


    首先创建一个通用请求接口的存储过程
    1. create PROCEDURE [GetHttpResponse]
    2. @url NVARCHAR(MAX), -- 请求地址
    3. @jsonBody NVARCHAR(MAX), -- 请求Body
    4. @statusCode INT OUTPUT, -- 状态
    5. @responseText NVARCHAR(MAX) OUTPUT -- 返回响应数据
    6. AS
    7. BEGIN
    8. BEGIN TRY
    9. -- 创建一个实例用于发送 HTTP 请求
    10. DECLARE @winHttp INT;
    11. EXEC sp_OACreate 'WinHttp.WinHttpRequest.5.1', @winHttp OUTPUT;
    12. -- 设置默认超时 (解析, 连接, 发送, 接收)
    13. DECLARE @timeout INT = 30000; -- 30秒超时
    14. EXEC sp_OAMethod @winHttp, 'SetTimeouts', NULL, @timeout, @timeout, @timeout, @timeout;
    15. -- 打开请求
    16. EXEC sp_OAMethod @winHttp, 'Open', NULL, 'POST', @url, 'false';
    17. -- 设置请求头
    18. EXEC sp_OAMethod @winHttp, 'SetRequestHeader', NULL, 'Content-Type', 'application/json';
    19. -- 发送请求
    20. EXEC sp_OAMethod @winHttp, 'Send', NULL, @jsonBody;--发送数据
    21. -- 获取响应状态码
    22. EXEC sp_OAGetProperty @winHttp, 'Status', @statusCode OUTPUT;
    23. -- 获取响应文本
    24. EXEC sp_OAGetProperty @winHttp, @responseText OUTPUT;
    25. -- 关闭请求
    26. EXEC sp_OADestroy @winHttp;
    27. END TRY
    28. BEGIN CATCH
    29. -- 如果发生异常,设置状态码为 -1
    30. SET @statusCode = -1;
    31. END CATCH
    32. END;
    调用上面的存储过程,请求API接口

    1. declare @title varchar(100) ='' --标题
    2. declare @content varchar(500)='' --内容
    3. ---發送釘釘消息
    4. declare @url nvarchar(max) = 'http://localhost:80/Msg/SengMsg'
    5. declare @jsonBody nvarchar(max)
    6. -- 将键值对转换为 JSON 格式
    7. set @jsonBody =
    8. N'{"title":"' + @title + '",' +
    9. N'"content":"' + @content + '"}'
    10. declare @statusCode int
    11. declare @responseText nvarchar(max)
    12. exec [iemis].[GetHttpResponse]
    13. @url = @url,
    14. @jsonBody = @jsonBody,
    15. @statusCode = @statusCode output,
    16. @responseText = @responseText output;

    然后写对应的SpringBoot接口

    1. @RestController
    2. @RequestMapping("/Msg")
    3. public class MessageController {
    4. @PostMapping("/SendMsg")
    5. public ResponseEntity sendMsg(@RequestBody MessageRequest messageRequest) {
    6. System.out.println("接受的数据 Title: " + messageRequest.getTitle() + ", Content: " + messageRequest.getContent());
    7. //加上你的接口处理逻辑
    8. return new ResponseEntity<>("成功", HttpStatus.OK);
    9. }
    10. }

  • 相关阅读:
    [附源码]计算机毕业设计JAVAjava航班资源车管理系统
    增速冠军 | 超云AI与信创实践典范,引领IDC中国服务器市场
    【LeetCode刷题-链表】--25.K个一组翻转链表
    MyBatis(二、基础进阶)
    智能终端信息安全概念(三):硬件安全技术—主芯片安全技术(1)
    (mac M1)Flutter环境搭建
    05 easyPoi的使用
    Oracle Unifier 22.12 ~ 23.10 功能改进清单表
    Leetcode 946.验证栈序列
    双十一买什么蓝牙耳机?价廉物美的蓝牙耳机推荐
  • 原文地址:https://blog.csdn.net/qq_41617901/article/details/139201221