我有一个简单的安卓客户端,需要‘对话’的一个简单的C# HTTP侦听器。我想通过在POST请求中传递用户名/密码来提供基本级别的身份验证。
MD5散列在C#中是微不足道的,可以提供足够的安全性来满足我的需求,但我似乎不知道如何在安卓端做到这一点。
编辑:只是为了解决人们对MD5弱点的担忧-- C#服务器运行在我的安卓客户端用户的PC上。在许多情况下,他们将在自己的局域网上使用wi-fi访问服务器,但风险自负,他们可能选择从互联网访问。此外,服务器上的服务需要使用MD5到我无法控制的第三方应用程序的直通。
发布于 2011-01-31 08:08:33
Here是一个您可以使用的实现(更新以使用更多最新的Java约定- for:each
循环,StringBuilder
而不是StringBuffer
):
public static 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 is considered broken and can be easily exploited)的系统使用它,但它有时足以完成基本任务。
发布于 2014-01-24 21:17:49
这个被接受的答案在我的Android2.2中不起作用。我不知道为什么,但它正在“吃”我的一些零(0)。Apache commons在Android2.2上也不起作用,因为它使用的方法只支持从Android2.3.x开始。此外,如果您只想MD5一个字符串,Apache commons太复杂了。为什么人们应该保留整个库,只使用其中的一个小函数……
最后,我找到了下面的代码片段here,它非常适合我。我希望它能对某些人有用。
public String MD5(String md5) {
try {
java.security.MessageDigest md = java.security.MessageDigest.getInstance("MD5");
byte[] array = md.digest(md5.getBytes("UTF-8"));
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) {
} catch(UnsupportedEncodingException ex){
}
return null;
}
发布于 2012-05-31 04:55:13
androidsnippets.com代码不能可靠地工作,因为0似乎被从产生的散列中去掉了。
更好的实现是here。
公共静态字符串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 =hash(1,m.digest()).toString(16);return hash;}
https://stackoverflow.com/questions/4846484
复制相似问题