Java SHA256/Base64转.NET,C#实现--

前言:

  工作需要,对接华为云应用市场的 API 接口,由于维护团队都是 .NET 所以用 .NET 来开发。

  简单了解一下 SHA256 加密算法,本质就是一个 Hash,与 MD5 相比就是计算量大一些,具体的没时间细化。

一、Java SHA256 加密算法实现代码  (最终以 Base64 方式进行签名验证)

 1 /**
 2 *
 3 * hamcSHA256加密算法
 4 * @param macKey 秘钥key
 5 * @param macData 加密内容-响应消息体
 6 * @return 加密密文
 7 * @throws NoSuchAlgorithmException
 8 * @throws InvalidKeyException
 9 * @throws IllegalStateException
10 * @throws UnsupportedEncodingException
11 */
12 public static byte[] hmacSHA256(String macKey, String macData) throws NoSuchAlgorithmException, InvalidKeyException, IllegalStateException, UnsupportedEncodingException {
13 
14     SecretKeySpec secret = new SecretKeySpec(macKey.getBytes(),  "HmacSHA256");
15     Mac mac = Mac.getInstance("HmacSHA256");
16     mac.init(secret);
17 
18     byte[] doFinal = mac.doFinal(macData.getBytes("UTF-8"));
19     return doFinal;
20 }
 1 /**
 2 *
 3 * 字节数组转字符串
 4 * @param bytes 字节数组
 5 * @return 字符串
 6 */
 7 public static String base_64(byte[] bytes)
 8 {
 9      return new String(Base64.encodeBase64(bytes));
10 }

二、.NET SHA256 加密算法实现代码

/// <summary>
/// hamcSHA256加密实现
/// </summary>
/// <returns>The token.</returns>
/// <param name="secret">Secret.</param>
/// <param name="message">Message.</param>
public static string CreateToken(string secret, string message)
{
     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); // 注意:Java (u127)与.NET byte(255) 存储方式不同,所以需要转换一下。 sbyte[] sb = new sbyte[hashmessage.Length]; for (int i = 0; i < hashmessage.Length; i++) { sb[i] = hashmessage[i] < 127 ? (sbyte)hashmessage[i] : (sbyte)(hashmessage[i] - 256); } byte[] unsignedByteArray = (byte[])(Array)sb; return Convert.ToBase64String(unsignedByteArray); } }

问题总结:

  1、转 byte[] 数组,注意编码格式;

  2、Java 中的 byte 与 .NET 中的 byte 存储方式不同,Java 是 -127~127、.NET 是 0~2555

  3、转换 Base64 同样,如果不进行转换结果会不一致,采用 sbyte[] 进行一轮转换再 Base64;