GeneralMethod.cs 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. using OASystem.Domain.Entities.PersonnelModule;
  2. using OASystem.Domain.Entities.System;
  3. using OASystem.Domain.ViewModels.PersonnelModule;
  4. using System.IdentityModel.Tokens.Jwt;
  5. using System.Security.Claims;
  6. namespace OASystem.API.OAMethodLib
  7. {
  8. public static class GeneralMethod
  9. {
  10. #region 消息
  11. #endregion
  12. #region md5 加密
  13. /// <summary>
  14. /// MD5加密,和动网上的16/32位MD5加密结果相同,
  15. /// 使用的UTF8编码
  16. /// </summary>
  17. /// <param name="source">待加密字串</param>
  18. /// <param name="length">16或32值之一,其它则采用.net默认MD5加密算法</param>
  19. /// <returns>加密后的字串</returns>
  20. public static string Encrypt(string source, int length = 32)
  21. {
  22. if (string.IsNullOrWhiteSpace(source))
  23. return string.Empty;
  24. HashAlgorithm hashAlgorithm = CryptoConfig.CreateFromName("MD5") as HashAlgorithm;
  25. byte[] bytes = Encoding.UTF8.GetBytes(source);
  26. byte[] hashValue = hashAlgorithm.ComputeHash(bytes);
  27. StringBuilder sb = new StringBuilder();
  28. switch (length)
  29. {
  30. case 16://16位密文是32位密文的9到24位字符
  31. for (int i = 4; i < 12; i++)
  32. {
  33. sb.Append(hashValue[i].ToString("x2"));
  34. }
  35. break;
  36. case 32:
  37. for (int i = 0; i < 16; i++)
  38. {
  39. sb.Append(hashValue[i].ToString("x2"));
  40. }
  41. break;
  42. default:
  43. for (int i = 0; i < hashValue.Length; i++)
  44. {
  45. sb.Append(hashValue[i].ToString("x2"));
  46. }
  47. break;
  48. }
  49. return sb.ToString();
  50. }
  51. #endregion
  52. #region jwt
  53. /// <summary>
  54. /// 获取token
  55. /// </summary>
  56. /// <param name="_config"></param>
  57. /// <param name="Number"></param>
  58. /// <param name="exp"></param>
  59. /// <returns></returns>
  60. public static string GetToken(IConfiguration _config,string Number,DateTime exp)
  61. {
  62. var claims = new[] {
  63. new Claim(ClaimTypes.NameIdentifier, "Future"),
  64. new Claim("Number",Number)
  65. };
  66. var key = new SymmetricSecurityKey(Encoding.UTF8.GetBytes(_config["JwtSecurityKey"]));
  67. var creds = new SigningCredentials(key, SecurityAlgorithms.HmacSha256);
  68. var token = new JwtSecurityToken(
  69. issuer: "OASystem.com",
  70. audience: "OASystem.com",
  71. claims: claims,
  72. expires: exp,
  73. signingCredentials: creds);
  74. return new JwtSecurityTokenHandler().WriteToken(token);
  75. }
  76. #endregion
  77. #region 数据类型转换
  78. /// <summary>
  79. /// object 转 Int
  80. /// </summary>
  81. /// <param name="obj"></param>
  82. /// <returns></returns>
  83. public static int GetInt(this object obj)
  84. {
  85. if (obj == null)
  86. return 0;
  87. int _number = 0;
  88. bool reslut = Int32.TryParse(obj.ToString(), out _number);
  89. return _number;
  90. }
  91. private static DateTime dateStart = new DateTime(1970, 1, 1, 8, 0, 0);
  92. private static long longTime = 621355968000000000;
  93. private static int samllTime = 10000000;
  94. /// <summary>
  95. /// 时间戳 转 datetime
  96. /// </summary>
  97. /// <param name="timeStamp"></param>
  98. /// <returns></returns>
  99. public static DateTime GetTimeSpmpToDate(this object timeStamp)
  100. {
  101. if (timeStamp == null) return dateStart;
  102. DateTime dateTime = new DateTime(longTime + Convert.ToInt64(timeStamp) * samllTime, DateTimeKind.Utc).ToLocalTime();
  103. return dateTime;
  104. }
  105. #endregion
  106. }
  107. }