MessageDigest的功能及用法

来源:互联网 发布:mysql gtid 编辑:程序博客网 时间:2024/05/20 08:44
MessageDigest 类为应用程序提供信息摘要算法的功能,如 MD5 或 SHA 算法。信息摘要是安全的单向哈希函数,它接收任意大小的数据,并输出固定长度的哈希值。

MessageDigest 对象开始被初始化。该对象通过使用 update()方法处理数据。任何时候都可以调用reset()方法重置摘要。一旦所有需要更新的数据都已经被更新了,应该调用digest()方法之一完成哈希计算。

对于给定数量的更新数据,digest 方法只能被调用一次。在调用 digest 之后,MessageDigest 对象被重新设置成其初始状态。

MessageDigest.getInstance(algorithm)

1、public static MessageDigest getInstance(String algorithm)                                 throws NoSuchAlgorithmException
   返回实现指定摘要算法的 MessageDigest 对象。
   algorithm - 所请求算法的名称
2、public static MessageDigest getInstance(String algorithm,                                        String provider)                                 throws NoSuchAlgorithmException,                                        NoSuchProviderException
  返回实现指定摘要算法的 MessageDigest 对象。
  algorithm - 所请求算法的名称
  provider - 提供者的名称。
3、public void update(byte[] input)
  使用指定的 byte 数组更新摘要。 
4、public byte[] digest()
  通过执行诸如填充之类的最终操作完成哈希计算。在调用此方法之后,摘要被重置。
5、public static boolean isEqual(byte[] digesta,                              byte[] digestb)
比较两个摘要的相等性。做简单的字节比较。

 

 

注意:Provider可以通过 java.security.Security.getProviders() 方法获取已注册提供者列表。比较常用的有“SUN”

SUN提供的常用的算法名称有:MD2 MD5                         SHA-1                         SHA-256                         SHA-384                         SHA-512

 

Code举例:

  
package encryption;import java.io.UnsupportedEncodingException;import java.security.MessageDigest;import java.security.NoSuchAlgorithmException;/** * 采用MD5加密解密 *  * @author tfq * @datetime 2011-10-13 */public class MD5Util {/*** * MD5加码 生成32位md5码 */public static String string2MD5(String inStr) {MessageDigest md5 = null;try { // 得到一个信息摘要器  md5 = MessageDigest.getInstance("MD5");} catch (Exception e) {System.out.println(e.toString());e.printStackTrace();return "";}char[] charArray = inStr.toCharArray();byte[] byteArray = new byte[charArray.length];for (int i = 0; i < charArray.length; i++)byteArray[i] = (byte) charArray[i];byte[] md5Bytes = md5.digest(byteArray);   StringBuffer hexValue = new StringBuffer();for (int i = 0; i < md5Bytes.length; i++) {// 与运算          // toHexString(b[n] & 0XFF)为什么要和0XFF做与运算  参考        //http://blog.csdn.net/wangyang1354/article/details/52290461int val = ((int) md5Bytes[i]) & 0xFF;   if (val < 16)hexValue.append("0");hexValue.append(Integer.toHexString(val));}return hexValue.toString();}/** * 加密解密算法 执行一次加密,两次解密 */public static String convertMD5(String inStr) {char[] a = inStr.toCharArray();for (int i = 0; i < a.length; i++) {a[i] = (char) (a[i] ^ 't');}String s = new String(a);return s;}// 测试主函数public static void main(String args[]) {String s = new String("tangfuqiang");System.err.println(Integer.parseInt("4646", 16));System.out.println("原始:" + s);System.out.println("MD5后:" + string2MD5(s));System.out.println("加密的:" + convertMD5(s));System.out.println("解密的:" + convertMD5(convertMD5(s)));}}

                                             
0 0
原创粉丝点击