• 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. }

  • 相关阅读:
    飞利浦Fidelio B97全景声家庭影院,让你在家享受“暑期档”
    nested exception is javax.mail.MessagingException: Exception reading response
    vue中封装el-table表格
    Apache OFBiz 路径遍历导致RCE漏洞复现(CVE-2024-36104)
    bitset优化
    React ts学习重点(组件状态,Hooks,路由)
    Spring Boot整合MyBatis
    Go Through an ML project
    【大厂AI课学习笔记NO.68】开源和开源发展情况
    多个excel合并
  • 原文地址:https://blog.csdn.net/qq_41617901/article/details/139201221