ApiLogService.cs 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. using System;
  2. using System.IO;
  3. using Datory;
  4. using GxPress.Common.AppOptions;
  5. using GxPress.Common.Tools;
  6. using GxPress.Entity;
  7. using GxPress.Service.Interface;
  8. using Microsoft.AspNetCore.Http;
  9. using Microsoft.Extensions.Configuration;
  10. using Microsoft.Extensions.Options;
  11. namespace GxPress.Service.Implement
  12. {
  13. public class ApiLogService : IApiLogService
  14. {
  15. private readonly IConfiguration _configuration;
  16. private readonly Repository<UserLogin> _repository;
  17. public ApiLogService(IConfiguration configuration, IOptionsMonitor<DatabaseOptions> dbOptionsAccessor)
  18. {
  19. _configuration = configuration;
  20. var databaseType =
  21. StringUtils.ToEnum<DatabaseType>(dbOptionsAccessor.CurrentValue.DatabaseType, DatabaseType.MySql);
  22. //_connectionString = dbOptionsAccessor.CurrentValue.ConnectionString;
  23. var database = new Database(databaseType, dbOptionsAccessor.CurrentValue.ConnectionString);
  24. _repository = new Repository<UserLogin>(database);
  25. }
  26. public async void DataSave(HttpContext context, long responseTime, int userId)
  27. {
  28. var isLog = _configuration.GetValue<bool>("ApiLog:IsEnable");
  29. // if (isLog)
  30. // {
  31. var requestMethod = context.Request.Method;
  32. var requestURL = $"{context.Request.Scheme}://{context.Request.Host}{context.Request.Path}";
  33. //var accessToken = context.GetTokenAsync("access_token").Result;//添加身份验证的项目可以使用此方法获取到access_toekn
  34. var accessToken = string.Empty;
  35. var requestBody = string.Empty;
  36. if (requestMethod == "POST")
  37. {
  38. context.Request.Body.Seek(0, SeekOrigin.Begin);
  39. var _reader = new StreamReader(context.Request.Body);
  40. requestBody = _reader.ReadToEnd();
  41. }
  42. var model=new UserLogin
  43. {
  44. AccessToken = accessToken,
  45. AccessTime = DateTime.Now,
  46. AccessAction = requestMethod,
  47. AccessApiUrl = requestURL,
  48. QueryString = context.Request.QueryString.ToString(),
  49. Body = requestBody,
  50. HttpStatus = context.Response.StatusCode,
  51. ClientIP = context.Connection.RemoteIpAddress.ToString(),
  52. ResponseTime = responseTime,
  53. UserId = userId
  54. };
  55. await _repository.InsertAsync(model);
  56. //}
  57. }
  58. }
  59. }