ASP.NET C# 實現釘釘簽名算法


在 https://open-doc.dingtalk.com/microapp/faquestions/hxs5v9 釘釘給出了JAVA/PHP算法,下面是C#算法

 
 using System.Security.Cryptography
using System.Text;
 private string hash_hmac2(string message, string secret)
        {
            secret = secret ?? "";
            var encoding = new System.Text.ASCIIEncoding();
            byte[] keyByte = encoding.GetBytes(secret);
            byte[] messageBytes = encoding.GetBytes(message);
            using (var hmacsha256 = new HMACSHA256(keyByte))
            {
                byte[] hashmessage = hmacsha256.ComputeHash(messageBytes);
                return Convert.ToBase64String(hashmessage);
            }
        }

 下面是調用代碼:

           login  timespan=1546084445901;
           string appsec = "testappSecret";

           sign= hash_hmac2(timespan.ToString(),appsec);
        
//此時sign為 HCbG3xNE3vzhO+u7qCUL1jS5hsu2n5r2cFhnTrtyDAE=
Response.Write(sign);

 下面是獲取時間戳

  public long GetTimeStamp()
        {
            TimeSpan ts = DateTime.UtcNow - new DateTime(1970, 1, 1, 0, 0, 0, 0);
            return Convert.ToInt64(ts.TotalSeconds);
        }

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM