GeneralMethod.cs 3.9 KB

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