首先创建一个通用请求接口的存储过程
create PROCEDURE [GetHttpResponse]@url NVARCHAR(MAX), -- 请求地址@jsonBody NVARCHAR(MAX), -- 请求Body@statusCode INT OUTPUT, -- 状态@responseText NVARCHAR(MAX) OUTPUT -- 返回响应数据
AS
BEGINBEGIN TRY-- 创建一个实例用于发送 HTTP 请求DECLARE @winHttp INT;EXEC sp_OACreate 'WinHttp.WinHttpRequest.5.1', @winHttp OUTPUT;-- 设置默认超时 (解析, 连接, 发送, 接收)DECLARE @timeout INT = 30000; -- 30秒超时EXEC sp_OAMethod @winHttp, 'SetTimeouts', NULL, @timeout, @timeout, @timeout, @timeout;-- 打开请求EXEC sp_OAMethod @winHttp, 'Open', NULL, 'POST', @url, 'false';-- 设置请求头EXEC sp_OAMethod @winHttp, 'SetRequestHeader', NULL, 'Content-Type', 'application/json';-- 发送请求EXEC sp_OAMethod @winHttp, 'Send', NULL, @jsonBody;--发送数据-- 获取响应状态码EXEC sp_OAGetProperty @winHttp, 'Status', @statusCode OUTPUT;-- 获取响应文本EXEC sp_OAGetProperty @winHttp, @responseText OUTPUT;-- 关闭请求EXEC sp_OADestroy @winHttp;END TRYBEGIN CATCH-- 如果发生异常,设置状态码为 -1SET @statusCode = -1;END CATCH
END;
调用上面的存储过程,请求API接口
declare @title varchar(100) ='' --标题
declare @content varchar(500)='' --内容
---發送釘釘消息
declare @url nvarchar(max) = 'http://localhost:80/Msg/SengMsg'
declare @jsonBody nvarchar(max)-- 将键值对转换为 JSON 格式
set @jsonBody = N'{"title":"' + @title + '",' +N'"content":"' + @content + '"}'
declare @statusCode int
declare @responseText nvarchar(max)exec [iemis].[GetHttpResponse]@url = @url,@jsonBody = @jsonBody,@statusCode = @statusCode output,@responseText = @responseText output;
然后写对应的SpringBoot接口
@RestController
@RequestMapping("/Msg")
public class MessageController {@PostMapping("/SendMsg")public ResponseEntity<String> sendMsg(@RequestBody MessageRequest messageRequest) {System.out.println("接受的数据 Title: " + messageRequest.getTitle() + ", Content: " + messageRequest.getContent());//加上你的接口处理逻辑return new ResponseEntity<>("成功", HttpStatus.OK);}
}