43 lines
2.1 KiB
C#
43 lines
2.1 KiB
C#
using BLL;
|
||
using System;
|
||
using System.Collections.Generic;
|
||
using System.Linq;
|
||
using System.Net.Http;
|
||
using System.Threading;
|
||
using System.Threading.Tasks;
|
||
using System.Web;
|
||
|
||
namespace WebAPI.Log
|
||
{
|
||
|
||
public class CustomMessageHandler : DelegatingHandler
|
||
{
|
||
protected override Task<HttpResponseMessage> SendAsync(HttpRequestMessage request, CancellationToken cancellationToken)
|
||
{
|
||
var requsestHeader = HttpContext.Current.Request.Headers.ToString();
|
||
var token = HttpContext.Current.Request.Headers["token"];
|
||
var username=BLL.UserService.GetUserNameByUserId(token);
|
||
//return base.SendAsync(request, cancellationToken);
|
||
//记录请求内容
|
||
if (request.Content != null)
|
||
{
|
||
//string msg = $"Request | Request Method: {request.Method},Request Uri: {request.RequestUri.AbsoluteUri}, Request Content: {request.Content.ReadAsStringAsync().Result}";
|
||
APICommonService.SaveSysHttpLog(username,request.RequestUri.AbsoluteUri, "Header :" + requsestHeader+"| Body :"+ request.Content.ReadAsStringAsync().Result, "Request|" + request.Method.ToString());
|
||
|
||
//LoggerHelper.Info(msg);
|
||
}
|
||
//发送HTTP请求到内部处理程序,在异步处理完成后记录相应内容
|
||
return base.SendAsync(request, cancellationToken).ContinueWith<HttpResponseMessage>((task) =>
|
||
{
|
||
var ResponseHeader = task.Result.Headers.ToString();
|
||
string result = task.Result.Content == null ? "Bad Request" : task.Result.Content.ReadAsStringAsync().Result;
|
||
// string msg = $"Response | Request Method:{request.Method},Request Uri: {request.RequestUri.AbsoluteUri}, Response Content: {result}";
|
||
APICommonService.SaveSysHttpLog(username,request.RequestUri.AbsoluteUri, "Header :" + ResponseHeader + "| Body :" + result, "Response|" + request.Method.ToString());
|
||
|
||
// 记录响应内容
|
||
/// LoggerHelper.Info(msg);
|
||
return task.Result;
|
||
});
|
||
}
|
||
}
|
||
} |