牛人啊,MD5解密算法

privatestaticvoidMD5(StringplainText){try{MessageDigestmd=MessageDigest.getInstance("... private static void MD5(String plainText) {
try {
MessageDigest md = MessageDigest.getInstance("MD5");
md.update(plainText.getBytes());
byte b[] = md.digest();

int i;

StringBuffer buf = new StringBuffer("");
for (int offset = 0; offset < b.length; offset++) {
i = b[offset];
if (i < 0)
i += 256;
if (i < 16)
buf.append("0");
buf.append(Integer.toHexString(i));
}
System.out.println("result: " + buf.toString());// 32位的加密
System.out.println("result: " + buf.toString().substring(8, 24));// 16位的加密
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
}
请帮我写一下这个MD5的解密算法
展开
 我来答
wufisher
推荐于2017-09-10 · TA获得超过3960个赞
知道小有建树答主
回答量:621
采纳率:0%
帮助的人:634万
展开全部
MD5是摘要算法,类似有损压缩一样,不能复原的,因此不能解密。

网上的使用一般是在用户点击提交的时候用js,或Java 加密后的密码存到数据库中,这时候别人如果打开数据库看也不知道你原来的密码是什么。但是你登录的时候输入密码后再重新用MD5摘要加密,看看出来的结果与数据库中是否一致,如果一致登录成功,不一致证明你输入错误了。

所以用MD5存密码,除了你谁都不知道密码是什么,但是如果你忘了也就不能去数据库看了,只能改密码,而不能找回。
江户川达也
2012-06-05
知道答主
回答量:11
采纳率:0%
帮助的人:4.6万
展开全部
这种东西没什么意义,MD5加密时,一般都会带几个其他参数,如:
md.update(password.getBytes()); //原密码
md.update(“param1”.getBytes()); //参数1
md.update(“param2”.getBytes()); //参数2
这样出来的密文和未带参数出来的密文完全不一样,你再怎么穷举也没用啊。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
帐号已注销
2008-08-11
知道答主
回答量:15
采纳率:0%
帮助的人:8万
展开全部
MD5 加密如果写出来就很厉害哦~!
据说中国有个教授写出来了
有段时间还闹得沸沸扬扬的
不过这东西普通人就用管了吧
能用就行了
像一楼说的那样要比较的话把要比较的数据加密后再去对比
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
稻草人9110
2018-09-12
知道答主
回答量:6
采纳率:0%
帮助的人:5448
展开全部
你是来作秀的吗,不知道md5不能解密?
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式