Android中的MD5散列
我有一个简单的Android客户端,需要与一个简单的C#HTTP侦听器“交谈”。 我想通过在POST请求中传递用户名/密码来提供基本级别的身份验证。
MD5散列在C#中是微不足道的,并为我的需求提供了足够的安全性,但我似乎无法找到如何在android端做到这一点。
编辑:只是为了解决关于MD5弱点提出的担忧 - C#服务器运行在我的Android客户端用户的PC上。 在很多情况下,他们将在他们自己的局域网上使用Wi-Fi访问服务器,但是他们可能会选择通过互联网访问它们,但风险自负。 此外,服务器上的服务需要使用MD5传递给我无法控制的第三方应用程序。
这里有一个你可以使用的实现(更新使用更多的Java约定 - for:each
循环, StringBuilder
而不是StringBuffer
):
public static final String md5(final String s) {
final String MD5 = "MD5";
try {
// Create MD5 Hash
MessageDigest digest = java.security.MessageDigest
.getInstance(MD5);
digest.update(s.getBytes());
byte messageDigest[] = digest.digest();
// Create Hex String
StringBuilder hexString = new StringBuilder();
for (byte aMessageDigest : messageDigest) {
String h = Integer.toHexString(0xFF & aMessageDigest);
while (h.length() < 2)
h = "0" + h;
hexString.append(h);
}
return hexString.toString();
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
return "";
}
尽管不建议系统甚至涉及基本的安全级别(MD5被认为是中断的并且可以被轻易利用),但它有时足以完成基本任务。
在Android 2.2中,我接受的答案并不适用于我。 我不知道为什么,但它“吃”了我的一些零(0)。 Apache公用程序也无法在Android 2.2上运行,因为它使用的方法仅支持从Android 2.3.x开始支持。 另外,如果你只想让MD5成为一个字符串,那么Apache commons就太复杂了。 为什么应该让整个图书馆只使用一个小功能......
最后,我在这里找到了下面的代码片段,这对我来说非常合适。 我希望它对某个人有用......
public String MD5(String md5) {
try {
java.security.MessageDigest md = java.security.MessageDigest.getInstance("MD5");
byte[] array = md.digest(md5.getBytes());
StringBuffer sb = new StringBuffer();
for (int i = 0; i < array.length; ++i) {
sb.append(Integer.toHexString((array[i] & 0xFF) | 0x100).substring(1,3));
}
return sb.toString();
} catch (java.security.NoSuchAlgorithmException e) {
}
return null;
}
androidsnippets.com代码无法可靠地工作,因为0似乎被切掉了结果散列。
这里有一个更好的实现。
public static String MD5_Hash(String s) {
MessageDigest m = null;
try {
m = MessageDigest.getInstance("MD5");
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
m.update(s.getBytes(),0,s.length());
String hash = new BigInteger(1, m.digest()).toString(16);
return hash;
}
链接地址: http://www.djcxy.com/p/21571.html