using Infrastructure.Model;
using Microsoft.AspNetCore.Http;
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Security.Claims;
using System.Text;
using System.Text.RegularExpressions;
using System.Threading.Tasks;
using UAParser;
using ZR.Common;
using ZR.Infrastructure.IPTools;
namespace Infrastructure.Extensions
{
///
/// HttpContext扩展类
///
public static partial class HttpContextExtension
{
///
/// 是否是ajax请求
///
///
///
public static bool IsAjaxRequest(this HttpRequest request)
{
if (request == null)
{
throw new ArgumentNullException(nameof(request));
}
//return request.Headers.ContainsKey("X-Requested-With") &&
// request.Headers["X-Requested-With"].Equals("XMLHttpRequest");
return request.Headers["X-Requested-With"] == "XMLHttpRequest" || request.Headers != null && request.Headers["X-Requested-With"] == "XMLHttpRequest";
}
///
/// 获取客户端IP
///
///
///
public static string GetClientUserIp(this HttpContext context)
{
if (context == null) return "";
var result = context.Request.Headers["X-Forwarded-For"].FirstOrDefault();
if (string.IsNullOrEmpty(result))
{
result = context.Connection.RemoteIpAddress?.ToString();
}
if (string.IsNullOrEmpty(result))
throw new Exception("获取IP失败");
if (result.Contains("::1"))
result = "127.0.0.1";
result = result.Replace("::ffff:", "");
result = result.Split(':')?.FirstOrDefault() ?? "127.0.0.1";
result = IsIP(result) ? result : "127.0.0.1";
return result;
}
///
/// 判断是否IP
///
///
///
public static bool IsIP(string ip)
{
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?)$");
}
///
/// 获取登录用户id
///
///
///
public static long GetUId(this HttpContext context)
{
var uid = context.User.FindFirstValue(ClaimTypes.PrimarySid);
return !string.IsNullOrEmpty(uid) ? long.Parse(uid) : 0;
}
///
/// 获取部门id
///
///
///
public static long GetDeptId(this HttpContext context)
{
var deptId = context.User.FindFirstValue(ClaimTypes.GroupSid);
return !string.IsNullOrEmpty(deptId) ? long.Parse(deptId) : 0;
}
///
/// 获取登录用户名
///
///
///
public static string GetName(this HttpContext context)
{
var uid = context.User?.Identity?.Name;
return uid;
}
///
/// 判断是否是管理员
///
///
///
public static bool IsAdmin(this HttpContext context)
{
var userName = context.GetName();
return userName == GlobalConstant.AdminRole;
}
///
/// ClaimsIdentity
///
///
///
public static IEnumerable GetClaims(this HttpContext context)
{
return context.User?.Identities;
}
//public static int GetRole(this HttpContext context)
//{
// var roleid = context.User.FindFirstValue(ClaimTypes.Role) ?? "0";
// return int.Parse(roleid);
//}
public static string GetUserAgent(this HttpContext context)
{
return context.Request.Headers["User-Agent"];
}
///
/// 获取请求令牌
///
///
///
public static string GetToken(this HttpContext context)
{
return context.Request.Headers["Authorization"];
}
///
/// 获取租户ID
///
///
///
public static string GetTenantId(this HttpContext context)
{
return context.Request.Headers["tenantId"];
}
///
/// 获取请求Url
///
///
///
public static string GetRequestUrl(this HttpContext context)
{
return context != null ? context.Request.Path.Value : "";
}
///
/// 获取请求参数
///
///
///
public static string GetQueryString(this HttpContext context)
{
return context != null ? context.Request.QueryString.Value : "";
}
///
/// 获取body请求参数
///
///
///
public static string GetBody(this HttpContext context)
{
context.Request.EnableBuffering();
//context.Request.Body.Seek(0, SeekOrigin.Begin);
//using var reader = new StreamReader(context.Request.Body, Encoding.UTF8);
////需要使用异步方式才能获取
//return reader.ReadToEndAsync().Result;
string body = string.Empty;
var buffer = new MemoryStream();
context.Request.Body.Seek(0, SeekOrigin.Begin);
context.Request.Body.CopyToAsync(buffer);
buffer.Position = 0;
try
{
using StreamReader streamReader = new(buffer, Encoding.UTF8);
body = streamReader.ReadToEndAsync().Result;
}
finally
{
buffer?.Dispose();
}
return body;
}
///
/// 获取body请求参数(异步)
///
///
///
public static async Task GetBodyAsync(this HttpContext context)
{
// 允许多次读取请求体
context.Request.EnableBuffering();
// 重置请求体流的位置,确保从头读取
context.Request.Body.Position = 0;
// 读取请求体内容
using var reader = new StreamReader(context.Request.Body, Encoding.UTF8, leaveOpen: true);
var body = await reader.ReadToEndAsync();
// 读取完成后将流位置重置为0,确保后续操作可以继续读取
context.Request.Body.Position = 0;
return body;
}
///
/// 获取浏览器信息
///
///
///
public static ClientInfo GetClientInfo(this HttpContext context)
{
var str = context.GetUserAgent();
var uaParser = Parser.GetDefault();
ClientInfo c = uaParser.Parse(str);
return c;
}
///
/// 根据IP获取地理位置
///
///
public static string GetIpInfo(string IP)
{
var ipInfo = IpTool.Search(IP);
return ipInfo?.Province + "-" + ipInfo?.City + "-" + ipInfo?.NetworkOperator;
}
///
/// 设置请求参数
///
///
///
public static string GetRequestValue(this HttpContext context, string reqMethod)
{
string param = string.Empty;
if (HttpMethods.IsPost(reqMethod) || HttpMethods.IsPut(reqMethod) || HttpMethods.IsDelete(reqMethod))
{
param = context.GetBody();
string regex = "(?<=\"password\":\")[^\",]*";
param = Regex.Replace(param, regex, "***");
}
if (param.IsEmpty())
{
param = context.GetQueryString();
}
return param;
}
///
/// 获取当前用户登录信息
///
///
///
public static TokenModel GetCurrentUser(this HttpContext context)
{
var tokenModel = JwtUtil.GetLoginUser(context);
if (tokenModel != null)
{
tokenModel.Permissions = (List)CacheHelper.GetCache(GlobalConstant.UserPermKEY + tokenModel.UserId);
}
return tokenModel;
}
///
/// 是否有敏感数据权限
///
///
///
///
public static bool HasSensitivePerm(this HttpContext context, string perm)
{
if (IsAdmin(context)) return true;
var perms = context.User?.FindFirst("sensitivePerms")?.Value?.Split(',') ?? [];
return perms.Contains(perm);
}
}
}