java中MessageDigest加密之后怎么还原出原字符串
展开全部
如果是MD5散列函数的结果,你拿到结果后转换成hex形式,然后去网上查下原值的。查一下就可以了。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
import java.security.MessageDigest;
public class SpiderMD5 {
public final static String MD5(String s) {
String result = "";
char hexDigits[] =
{ '0', '1', '2', '3',
'4', '5', '6', '7',
'8', '9', 'a', 'b',
'c', 'd', 'e', 'f' };
try {
byte[] strTemp = s.getBytes();
MessageDigest mdTemp = MessageDigest.getInstance("MD5");
mdTemp.update(strTemp);
byte[] md = mdTemp.digest();
int j = md.length;
char str[] = new char[j * 2];
int k = 0;
for (int i = 0; i < j; i++) {
byte b = md[i];
str[k++] = hexDigits[b >> 4 & 0xf];
str[k++] = hexDigits[b & 0xf];
}
result = new String(str);
} catch (Exception e)
return result;
}
}
public class SpiderMD5 {
public final static String MD5(String s) {
String result = "";
char hexDigits[] =
{ '0', '1', '2', '3',
'4', '5', '6', '7',
'8', '9', 'a', 'b',
'c', 'd', 'e', 'f' };
try {
byte[] strTemp = s.getBytes();
MessageDigest mdTemp = MessageDigest.getInstance("MD5");
mdTemp.update(strTemp);
byte[] md = mdTemp.digest();
int j = md.length;
char str[] = new char[j * 2];
int k = 0;
for (int i = 0; i < j; i++) {
byte b = md[i];
str[k++] = hexDigits[b >> 4 & 0xf];
str[k++] = hexDigits[b & 0xf];
}
result = new String(str);
} catch (Exception e)
return result;
}
}
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询