HttpContextExtension.cs 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181
  1. using Infrastructure;
  2. using Infrastructure.Extensions;
  3. using Microsoft.AspNetCore.Authentication;
  4. using Microsoft.AspNetCore.Authentication.JwtBearer;
  5. using Microsoft.AspNetCore.Http;
  6. using System;
  7. using System.Collections.Generic;
  8. using System.IO;
  9. using System.Linq;
  10. using System.Security.Claims;
  11. using System.Text;
  12. using System.Text.RegularExpressions;
  13. using System.Threading.Tasks;
  14. using UAParser;
  15. using ZR.Model.System;
  16. namespace ZR.Admin.WebApi.Extensions
  17. {
  18. /// <summary>
  19. /// HttpContext扩展类
  20. /// </summary>
  21. public static class HttpContextExtension
  22. {
  23. /// <summary>
  24. /// 是否是ajax请求
  25. /// </summary>
  26. /// <param name="request"></param>
  27. /// <returns></returns>
  28. public static bool IsAjaxRequest(this HttpRequest request)
  29. {
  30. if (request == null)
  31. {
  32. throw new ArgumentNullException(nameof(request));
  33. }
  34. //return request.Headers.ContainsKey("X-Requested-With") &&
  35. // request.Headers["X-Requested-With"].Equals("XMLHttpRequest");
  36. return request.Headers["X-Requested-With"] == "XMLHttpRequest" || (request.Headers != null && request.Headers["X-Requested-With"] == "XMLHttpRequest");
  37. }
  38. /// <summary>
  39. /// 获取客户端IP
  40. /// </summary>
  41. /// <param name="context"></param>
  42. /// <returns></returns>
  43. public static string GetClientUserIp(this HttpContext context)
  44. {
  45. if (context == null) return "";
  46. var result = context.Request.Headers["X-Forwarded-For"].FirstOrDefault();
  47. if (string.IsNullOrEmpty(result))
  48. {
  49. result = context.Connection.RemoteIpAddress?.ToString();
  50. }
  51. if (string.IsNullOrEmpty(result) || result.Contains("::1"))
  52. result = "127.0.0.1";
  53. result = result.Replace("::ffff:", "127.0.0.1");
  54. result = IsIP(result) ? result : "127.0.0.1";
  55. return result;
  56. }
  57. public static bool IsIP(string ip)
  58. {
  59. return Regex.IsMatch(ip, @"^((2[0-4]\d|25[0-5]|[01]?\d\d?)\.){3}(2[0-4]\d|25[0-5]|[01]?\d\d?)$");
  60. }
  61. /// <summary>
  62. /// 获取登录用户id
  63. /// </summary>
  64. /// <param name="context"></param>
  65. /// <returns></returns>
  66. public static long GetUId(this HttpContext context)
  67. {
  68. var uid = context.User.FindFirstValue(ClaimTypes.PrimarySid);
  69. return !string.IsNullOrEmpty(uid) ? long.Parse(uid) : 0;
  70. }
  71. /// <summary>
  72. /// 获取登录用户名
  73. /// </summary>
  74. /// <param name="context"></param>
  75. /// <returns></returns>
  76. public static string? GetName(this HttpContext context)
  77. {
  78. var uid = context.User?.Identity?.Name;
  79. return uid;
  80. }
  81. /// <summary>
  82. /// 判断是否是管理员
  83. /// </summary>
  84. /// <param name="context"></param>
  85. /// <returns></returns>
  86. public static bool IsAdmin(this HttpContext context)
  87. {
  88. var userName = GetName(context);
  89. return userName == GlobalConstant.AdminRole;
  90. }
  91. /// <summary>
  92. /// ClaimsIdentity
  93. /// </summary>
  94. /// <param name="context"></param>
  95. /// <returns></returns>
  96. public static IEnumerable<ClaimsIdentity>? GetClaims(this HttpContext context)
  97. {
  98. return context.User?.Identities;
  99. }
  100. //public static int GetRole(this HttpContext context)
  101. //{
  102. // var roleid = context.User.FindFirstValue(ClaimTypes.Role) ?? "0";
  103. // return int.Parse(roleid);
  104. //}
  105. public static string GetUserAgent(this HttpContext context)
  106. {
  107. return context.Request.Headers["User-Agent"];
  108. }
  109. /// <summary>
  110. /// 获取请求令牌
  111. /// </summary>
  112. /// <param name="context"></param>
  113. /// <returns></returns>
  114. public static string GetToken(this HttpContext context)
  115. {
  116. return context.Request.Headers["Authorization"];
  117. }
  118. public static ClientInfo GetClientInfo(this HttpContext context)
  119. {
  120. var str = GetUserAgent(context);
  121. var uaParser = Parser.GetDefault();
  122. ClientInfo c = uaParser.Parse(str);
  123. return c;
  124. }
  125. public static string? GetRequestUrl(this HttpContext context)
  126. {
  127. return context != null ? context.Request.Path.Value : "";
  128. }
  129. public static string GetQueryString(this HttpContext context)
  130. {
  131. return context != null ? context.Request.QueryString.Value : "";
  132. }
  133. /// <summary>
  134. /// 设置请求参数
  135. /// </summary>
  136. /// <param name="operLog"></param>
  137. /// <param name="context"></param>
  138. public static void GetRequestValue(this HttpContext context, SysOperLog operLog)
  139. {
  140. string reqMethod = operLog.RequestMethod;
  141. string param;
  142. if (HttpMethods.IsPost(reqMethod) || HttpMethods.IsPut(reqMethod) || HttpMethods.IsDelete(reqMethod))
  143. {
  144. context.Request.Body.Seek(0, SeekOrigin.Begin);
  145. using var reader = new StreamReader(context.Request.Body, Encoding.UTF8);
  146. //需要使用异步方式才能获取
  147. param = reader.ReadToEndAsync().Result;
  148. if (param.IsEmpty())
  149. {
  150. param = GetQueryString(context);
  151. }
  152. }
  153. else
  154. {
  155. param = GetQueryString(context);
  156. }
  157. operLog.OperParam = param;
  158. }
  159. }
  160. }