Signature.cs 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. using Microsoft.AspNetCore.Mvc;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.Linq;
  5. using System.Security.Cryptography;
  6. using System.Text;
  7. using System.Threading.Tasks;
  8. namespace ConsoleApp1.OCPPAuth
  9. {
  10. internal static class Signature
  11. {
  12. public static void Test()
  13. {
  14. string signature = GetSignature(
  15. timestamp: "1731561763",
  16. partnerid: "8456AED9-6DD9-4BF3-A94C-9F5DCB9506F7",
  17. saltkey: "gfdfgy!12",
  18. requestUrl: "http://ebus-coreapi.azurewebsites.net/api/v1/ocpp16/diagnostics?ChargeBoxId=AXLU111001D1P1ZERO&Location=https://buscharge.zerovatech.com/service/File/&StartTime=2024-11-14&StopTime=2024-11-14");
  19. }
  20. private static string GetSignature(string timestamp, string partnerid, string saltkey , string requestUrl = "", string requestBody = "")
  21. {
  22. string diplayUrl = requestUrl.Replace("%20", " ").Replace(@"\\", @"\");
  23. string tempText = diplayUrl.Substring(diplayUrl.IndexOf('?') + 1).ToLower();
  24. tempText = tempText.StartsWith("http") ? string.Empty : tempText;
  25. var body = $"{tempText}{requestBody}";
  26. var unencodeText = $"{body}{timestamp}{partnerid}{saltkey}".ToLower();
  27. var signature = GetSignature(unencodeText);
  28. return signature;
  29. }
  30. private static string GetSignature(string unencodeText)
  31. {
  32. if ((unencodeText == null) || (unencodeText.Length == 0))
  33. {
  34. return String.Empty;
  35. }
  36. unencodeText = unencodeText.ToLower();
  37. MD5 md5 = MD5.Create();// new MD5CryptoServiceProvider();
  38. byte[] textToHash = Encoding.UTF8.GetBytes(unencodeText);
  39. byte[] result = md5.ComputeHash(textToHash);
  40. return BitConverter.ToString(result).Replace("-", "").ToLower();
  41. }
  42. }
  43. }