ApiLogService.cs 2.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  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. private readonly Repository<User> _userRepository;
  18. public ApiLogService(IConfiguration configuration, IOptionsMonitor<DatabaseOptions> dbOptionsAccessor)
  19. {
  20. _configuration = configuration;
  21. var databaseType =
  22. StringUtils.ToEnum<DatabaseType>(dbOptionsAccessor.CurrentValue.DatabaseType, DatabaseType.MySql);
  23. //_connectionString = dbOptionsAccessor.CurrentValue.ConnectionString;
  24. var database = new Database(databaseType, dbOptionsAccessor.CurrentValue.ConnectionString);
  25. _repository = new Repository<UserLogin>(database);
  26. _userRepository = new Repository<User>(database);
  27. }
  28. public async void DataSave(HttpContext context, long responseTime, int userId)
  29. {
  30. var isLog = _configuration.GetValue<bool>("ApiLog:IsEnable");
  31. // if (isLog)
  32. // {
  33. var requestMethod = context.Request.Method;
  34. var requestURL = $"{context.Request.Scheme}://{context.Request.Host}{context.Request.Path}";
  35. //var accessToken = context.GetTokenAsync("access_token").Result;//添加身份验证的项目可以使用此方法获取到access_toekn
  36. var accessToken = string.Empty;
  37. var requestBody = string.Empty;
  38. if (requestMethod == "POST")
  39. {
  40. context.Request.Body.Seek(0, SeekOrigin.Begin);
  41. var _reader = new StreamReader(context.Request.Body);
  42. requestBody = _reader.ReadToEnd();
  43. }
  44. var model = new UserLogin
  45. {
  46. AccessToken = accessToken,
  47. AccessTime = DateTime.Now,
  48. AccessAction = requestMethod,
  49. AccessApiUrl = requestURL,
  50. QueryString = context.Request.QueryString.ToString(),
  51. Body = requestBody,
  52. HttpStatus = context.Response.StatusCode,
  53. ClientIP = context.Connection.RemoteIpAddress.ToString(),
  54. ResponseTime = responseTime,
  55. UserId = userId
  56. };
  57. await _repository.InsertAsync(model);
  58. //
  59. await _userRepository.UpdateAsync(Q.Where(nameof(User.Id), userId).Set(nameof(User.LoginTime), DateTime.Now));
  60. //}
  61. }
  62. }
  63. }