我在安卓上使用HMAC遇到了问题。我正在使用SHA1算法并使用以下代码,这个代码在搜索android hmac-sha1时出现得到处都是。
String base_string = "This is a test string";
String key = "testKey";
try {
Mac mac = Mac.getInstance("HmacSHA1");
SecretKeySpec secret = new SecretKeySpec(key.getBytes("UTF-8"), mac.getAlgorithm());
mac.init(secret);
byte[] digest = mac.doFinal(base_string.getBytes());
String enc = new String(digest);
// Base 64 Encode the results
String retVal = Base64.encodeBase64String(enc.getBytes());
Log.v(TAG, "String: " + base_string);
Log.v(TAG, "key: " + key);
Log.v(TAG, "result: " + retVal);
} catch (Exception e) {
System.out.println(e.getMessage());
}
为了测试这段代码,我创建了一个简单的标准Java程序(当然要使用 System.out.println 调用代替 Log.v 调用),以便与Android版本进行比较。在两种情况下,我都使用相同的测试值作为 base_string 和 key。
此外,我已经通过一些PHP函数和验证服务器(使用一些OAuth令牌)验证了标准Java的编码结果。代码在标准Java程序中运行良好,但在Android程序中却无法正常工作。我做了很多搜索,但是找不出错在哪里。有人遇到过类似问题吗?
以下是标准Java和Android的结果...
Java(和PHP):fH/+pz0J5XcPZH/d608zGSn7FKA=
Android程序:fH/vv73vv709Ce+/vXcPZH/vv73vv71PMxkp77+9FO+/vQ==
更深入地研究后,我确信是 hmac 函数而不是 Base64 编码出现问题,因为将这些 hmac 值进行比较,Android版本与Java程序相比具有所有类型的额外空格和其他未知字符符号。
感谢任何帮助!
android.util.Base64.encodeBase64String(...)
。 - AlikElzin-kilaka