注册
 找回密码
 注册
江西广告网
查看: 299|回复: 0
打印 上一主题 下一主题

Java

[复制链接]

该用户从未签到

1
跳转到指定楼层
发表于 2009-1-16 09:43:45 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?注册

x
Java 的MessageDigest 提供了生产MD5的算法,但是它返回的是byte[],以下方法实现了MD5值为16进制字符串的返回值。 由于没有找到现成的转换方法,采用的是对每个字节比较来实现的. public class MD5Security { private final static char[] hexDigits = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F' }; private static String bytesToHex(byte[] bytes) { StringBuffer sb = new StringBuffer(); int t; for (int i = 0; i < 16; i ) {// 16 == bytes.length; t = bytes[i]; if (t < 0) t =256; sb.append(hexDigits[(t >>> 4)]); sb.append(hexDigits[(t % 16)]); } return sb.toString(); } public static String code(String input) throws Exception { try { MessageDigest md = MessageDigest.getInstance(System.getProperty( "MD5.algorithm", "MD5")); return bytesToHex(md.digest(input.getBytes("utf-8"))); } catch (NoSuchAlgorithmException e) { e.printStackTrace(); throw new Exception("Could not found MD5 algorithm.", e); } } }
您需要登录后才可以回帖 登录 | 注册

本版积分规则

快速回复 返回顶部 返回列表