HaoDa.cs 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. using System;
  2. using System.Collections.Generic;
  3. using System.IO;
  4. using System.Security.Cryptography;
  5. using System.Text;
  6. using System.Threading;
  7. using Common;
  8. using Infrastructure;
  9. using LitJson;
  10. using Microsoft.AspNetCore.Mvc;
  11. using Model;
  12. using Services;
  13. namespace Util
  14. {
  15. public class HaoDa
  16. {
  17. public readonly static HaoDa Instance = new HaoDa();
  18. private HaoDa()
  19. { }
  20. #region 好哒
  21. //测试环境
  22. string PublicKey = "MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAjMQxp24mjxDTr13uPW0y+tiO1yXFGw7P/pPQ0oZKK7F6KstEaus7pLEywBZ5XRXE5jgkhR2TS7Ne7djJfbpn5yFc6pPlz3ZsOfBVeB88NEwhx6xzCGX2eqSSkO33n8w2G0xc2ss5HpYBarT00NBZWhrwOXpdRPYLOYHKVU3Rl+FA9xDw/wYfoWvrr+JSfHRGn/ENMmQFEdckAbPauKaQMrZD2kz+PRrhq56eWnCuVQPcaz/jroVT8qQEgkg2IsNy+DwfLOIqm8IySEpxnQ5wN/KvsQJc2wXDQNf9F5kvWwjoqSSP0qJS+oPRXET+zJb+WTk2y5M6AYoC9NodwsC4NwIDAQAB";
  23. //生产环境
  24. // string PublicKey = "MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAjmjoQirIYZBD9Qon2HkF4j/NAINXtJ7Lzq/WXxTF7t7mg7LNARt0+ZZaeWx8caq2fv5zdsGyyoInL23cBtDI5KmFfK69iA0ygQMK0WbiKqsUB1OpPbT3+9zLuadIJAznjA223lY6CIjTpdLZhaRjImNVqc60bdkx6YsQcA+xW+3r1JH4PPHb7yBEbkKIX8OhyX7U4p0TkbDkAobbjHr5YB9gmYLoSFJMOPfTtSExkv7/Y7IVR9poZAHcr3teFoAiXW3RzxelRtnXxIkl/6AUOKoL5fhr/UTUN+Q18uzNljYWr6SwnTI3EmtzgykaewWtZvV85Xdhe/BjiQ5Xor7YbwIDAQAB";
  25. public bool VerifySign(string toSignStr, string signStr)
  26. {
  27. return true;
  28. byte[] toSignByte = Encoding.Default.GetBytes(toSignStr);
  29. byte[] signByte = Convert.FromBase64String(signStr);
  30. var toKey = Convert.FromBase64String(PublicKey);
  31. var rsaroot = RSA.Create();
  32. rsaroot.ImportSubjectPublicKeyInfo(toKey, out _);
  33. var publicKeyParameters = rsaroot.ExportParameters(false);
  34. using (var rsa = RSA.Create())
  35. {
  36. rsa.ImportParameters(publicKeyParameters);
  37. var sha256 = SHA256.Create();
  38. var hash = sha256.ComputeHash(toSignByte);
  39. return rsa.VerifyHash(hash, signByte, HashAlgorithmName.SHA256, RSASignaturePadding.Pkcs1);
  40. }
  41. }
  42. // public bool VerifySign(string toSignStr, string signStr)
  43. // {
  44. // byte[] toSignByte = Encoding.Default.GetBytes(toSignStr);
  45. // byte[] signByte = Convert.FromBase64String(signStr);
  46. // var toKey = Convert.FromBase64String(PublicKey);
  47. // var rsaroot = RSA.Create();
  48. // rsaroot.ImportRSAPublicKey(toKey, out _);
  49. // using (var rsa = RSA.Create())
  50. // {
  51. // var sha256 = SHA256.Create();
  52. // var hash = sha256.ComputeHash(toSignByte);
  53. // return rsa.VerifyHash(hash, signByte, HashAlgorithmName.SHA256, RSASignaturePadding.Pkcs1);
  54. // }
  55. // }
  56. #endregion
  57. }
  58. }