GMUtil.cs 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. // 麻省理工学院许可证
  2. //
  3. // 版权所有 (c) 2021-2023 zuohuaijun,大名科技(天津)有限公司 联系电话/微信:18020030720 QQ:515096995
  4. //
  5. // 特此免费授予获得本软件的任何人以处理本软件的权利,但须遵守以下条件:在所有副本或重要部分的软件中必须包括上述版权声明和本许可声明。
  6. //
  7. // 软件按“原样”提供,不提供任何形式的明示或暗示的保证,包括但不限于对适销性、适用性和非侵权的保证。
  8. // 在任何情况下,作者或版权持有人均不对任何索赔、损害或其他责任负责,无论是因合同、侵权或其他方式引起的,与软件或其使用或其他交易有关。
  9. using Org.BouncyCastle.Crypto;
  10. using Org.BouncyCastle.Math;
  11. using Org.BouncyCastle.Utilities.Encoders;
  12. namespace Admin.NET.Core;
  13. /// <summary>
  14. /// GM工具类
  15. /// </summary>
  16. public class GMUtil
  17. {
  18. public const string SM4_key = "0123456789abcdeffedcba9876543210";
  19. public const string SM4_iv = "595298c7c6fd271f0402f804c33d3f66";
  20. /// <summary>
  21. /// SM2加密
  22. /// </summary>
  23. /// <param name="publicKeyHex"></param>
  24. /// <param name="data_string"></param>
  25. /// <returns></returns>
  26. public static string SM2Encrypt(string publicKeyHex, string data_string)
  27. {
  28. // 如果是130位公钥,.NET使用的话,把开头的04截取掉
  29. if (publicKeyHex.Length == 130)
  30. {
  31. publicKeyHex = publicKeyHex.Substring(2, 128);
  32. }
  33. // 公钥X,前64位
  34. string x = publicKeyHex.Substring(0, 64);
  35. // 公钥Y,后64位
  36. string y = publicKeyHex.Substring(64);
  37. // 获取公钥对象
  38. AsymmetricKeyParameter publicKey1 = GM.GetPublickeyFromXY(new BigInteger(x, 16), new BigInteger(y, 16));
  39. // Sm2Encrypt: C1C3C2
  40. // Sm2EncryptOld: C1C2C3
  41. byte[] digestByte = GM.Sm2Encrypt(Hex.Decode(data_string), publicKey1);
  42. string strSM2 = Hex.ToHexString(digestByte);
  43. return strSM2;
  44. }
  45. /// <summary>
  46. /// SM2解密
  47. /// </summary>
  48. /// <param name="privateKey_string"></param>
  49. /// <param name="encryptedData_string"></param>
  50. /// <returns></returns>
  51. public static string SM2Decrypt(string privateKey_string, string encryptedData_string)
  52. {
  53. if (!encryptedData_string.StartsWith("04"))
  54. encryptedData_string = "04" + encryptedData_string;
  55. BigInteger d = new(privateKey_string, 16);
  56. // 先拿到私钥对象,用ECPrivateKeyParameters 或 AsymmetricKeyParameter 都可以
  57. // ECPrivateKeyParameters bcecPrivateKey = GmUtil.GetPrivatekeyFromD(d);
  58. AsymmetricKeyParameter bcecPrivateKey = GM.GetPrivatekeyFromD(d);
  59. byte[] byToDecrypt = Hex.Decode(encryptedData_string);
  60. byte[] byDecrypted = GM.Sm2Decrypt(byToDecrypt, bcecPrivateKey);
  61. string strDecrypted = Encoding.UTF8.GetString(byDecrypted);
  62. return strDecrypted;
  63. }
  64. /// <summary>
  65. /// SM4加密(ECB)
  66. /// </summary>
  67. /// <param name="plainText"></param>
  68. /// <returns></returns>
  69. public static string SM4EncryptECB(string plainText)
  70. {
  71. byte[] key = Hex.Decode(SM4_key);
  72. byte[] bs = GM.Sm4EncryptECB(key, Hex.Decode(plainText), GM.SM4_ECB_NOPADDING);
  73. return Hex.ToHexString(bs);
  74. }
  75. /// <summary>
  76. /// SM4解密(ECB)
  77. /// </summary>
  78. /// <param name="cipherText"></param>
  79. /// <returns></returns>
  80. public static string SM4DecryptECB(string cipherText)
  81. {
  82. byte[] key = Hex.Decode(SM4_key);
  83. byte[] bs = GM.Sm4DecryptECB(key, Hex.Decode(cipherText), GM.SM4_ECB_NOPADDING);
  84. return Encoding.UTF8.GetString(bs);
  85. }
  86. /// <summary>
  87. /// SM4加密(CBC)
  88. /// </summary>
  89. /// <param name="plainText"></param>
  90. /// <returns></returns>
  91. public static string SM4EncryptCBC(string plainText)
  92. {
  93. byte[] key = Hex.Decode(SM4_key);
  94. byte[] iv = Hex.Decode(SM4_iv);
  95. byte[] bs = GM.Sm4EncryptCBC(key, Hex.Decode(plainText), iv, GM.SM4_CBC_NOPADDING);
  96. return Hex.ToHexString(bs);
  97. }
  98. /// <summary>
  99. /// SM4解密(CBC)
  100. /// </summary>
  101. /// <param name="cipherText"></param>
  102. /// <returns></returns>
  103. public static string SM4DecryptCBC(string cipherText)
  104. {
  105. byte[] key = Hex.Decode(SM4_key);
  106. byte[] iv = Hex.Decode(SM4_iv);
  107. byte[] bs = GM.Sm4DecryptCBC(key, Hex.Decode(cipherText), iv, GM.SM4_CBC_NOPADDING);
  108. return Encoding.UTF8.GetString(bs);
  109. }
  110. }