Java实现MD5消息摘要算法

首先,必须要强调的一点,MD5不是加密算法,而是消息摘要算法,具有不可逆性。字符串通过MD5处理后会生成128位的二进制串。我们通常会将其转化为16进制串,用于登录密码验证。

加密算法与消息摘要算法区别:

  1. 加密算法具有相应地解密算法,通过加密算法对信息进行加密后,采用解密算法能够获取到原始数据。
  2. 采用摘要算法得到的数据是不完整的,无法反向获取到原始数据。

下面直接贴代码:

import java.security.MessageDigest;//Java类库已经支持MD5消息摘要

public class MD5{
  private MD5(){
    System.out.println("采用MD5消息摘要算法");
  }

  public static String getMD5Code(String message){
    String md5Str = null;
    try{
      MessageDigest md = MessageDigest.getInstance("MD5");

      //message.getBytes()方法是得到一个操作系统默认的编码格式的字节数组。不同的操作系统以及不同的编码格式会返回不同长度的byte型数组。
      //md.digest()方法获得密文完成哈希计算,产生128位的二进制串,并且8位一组分成16个byte类型的数值。
      byte[] md5Bytes = md.digest(message.getBytes());

      //将16个数值都转换成两位16进制的数(161->A1,1->01),因此消息摘要完成后,md5Str是长度为32位的字符串
      md5Str = BytesToHex(md5Bytes);
    }catch(Exception e){
      e.printStackTrace();
    }
    return md5Str;
  }

  public static String BytesToHex(byte[] bytes){
    StringBuffer s = new StringBuffer();
    for(int i=0;i<bytes.length;i++){
      //如果数值小于16且大于0,如3,将其转换为03
      if(bytes[i]>=0 && bytes[i] <= 15)
        s.append("0");

      //bytes[i] & 0xFF保证了如果bytes[I]是负数,那么结果仍为两位16进制数;
      //toHexString()用于将参数以16进制的字符串形式返回,例如toHexString(241)返回值是字符串f1
      s.append(Integer.toHexString(bytes[i] & 0xFF);
    }
    return s.toString();
  }

  public static void main(String args[]){
    System.out.println(getMD5Code("shanghai"));
    System.out.println(getMD5Code("beijing"));
    System.out.println(getMD5Code("shanghai"));
  }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • java实现的MD5摘要算法完整实例

    本文实例讲述了java实现的MD5摘要算法.分享给大家供大家参考,具体如下: package com.soufun.com; import java.io.UnsupportedEncodingException; import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; /** * @author WHD */ public class MD5Test { // MD5 单向加密 pub

  • Java实现MD5消息摘要算法

    首先,必须要强调的一点,MD5不是加密算法,而是消息摘要算法,具有不可逆性.字符串通过MD5处理后会生成128位的二进制串.我们通常会将其转化为16进制串,用于登录密码验证. 加密算法与消息摘要算法区别: 加密算法具有相应地解密算法,通过加密算法对信息进行加密后,采用解密算法能够获取到原始数据. 采用摘要算法得到的数据是不完整的,无法反向获取到原始数据. 下面直接贴代码: import java.security.MessageDigest;//Java类库已经支持MD5消息摘要 public

  • Java MD5消息摘要算法原理及实现代码

    md5 属于hash算法一类,是不可逆的消息摘要算法.与对称加密和非对称加密算法不一样,不需要加密密钥. 注意: md5不是加密算法,只是将数据进行散列计算后生成一个唯一值的算法,没有加密密钥也没有解密密钥. 下面说的md5加密是指对密码加密成32位长度字符串的过程 md5可以用于密码的加密,如123456,加密后的字符串,在很大条件下不能被电脑强行破解出来,只能通过字典匹配的方式同样用md5加密后的字符串进行比较破解. MessageDigest消息摘要是安全的单向散列函数,它将任意大小的字符

  • Java加密 消息摘要算法SHA实现详解

    SHA是消息摘要算法的一种实现方式,前面已经总结过MD2\4\5的实现,接下来就为大家总结一下SHA的实现. SHA的jdk实现: private static void SHA_JDK(){ try { MessageDigest digest = MessageDigest.getInstance("SHA");//我们可以通过SHA\SHA-1\SHA-384\SHA-256\SHA-512来获得不同的消息摘要密钥 digest.update(src.getBytes()); S

  • Java加密 消息摘要算法MAC实现详解

    MAC是消息摘要算法的第三种实现方式,另外两种方式分别为:MD2\4\5.SHA. MAC的jdk实现:1.默认密钥方式 private static void MAC_JDK(){ try { KeyGenerator keyGenerator = KeyGenerator.getInstance("HmacMD5");//初始化KeyGenerator SecretKey secretKey = keyGenerator.generateKey();//产生密钥 byte[] ke

  • Java消息摘要算法MAC实现与应用完整示例

    本文实例讲述了Java消息摘要算法MAC实现与应用.分享给大家供大家参考,具体如下: 一 介绍 MAC:Message Authentication Code HMAC:keyed-Hash Message Authencication Code,含有密钥的散列函数算法. 融合MD.SHA MD系列:HmacMD2.HmacMD4.HmacMD5 SHA系列:HmacSHA1.HmacSHA224.HmacSHA256.HmacSHA384.HmacSHA512 应用:SecureCRT 二 参

  • 使用java获取md5值的两种方法

    Message Digest Algorithm MD5(中文名为消息摘要算法第五版)为计算机安全领域广泛使用的一种散列函数,是一种比较常用的哈希算法. java中可以用两种方法实现,我们先说麻烦一点的,代码: 复制代码 代码如下: public class md5_test { //MD5的字符串常量 private final static String[] hexDigits = { "0", "1", "2", "3"

  • Java的MD5工具类和客户端测试类

    什么是MD5? Message Digest Algorithm MD5(中文名为消息摘要算法第五版)为计算机安全领域广泛使用的一种散列函数,用以提供消息的完整性保护.该算法的文件号为RFC 1321(R.Rivest,MIT Laboratory for Computer Science and RSA Data Security Inc. April 1992). MD5即Message-Digest Algorithm 5(信息-摘要算法5),用于确保信息传输完整一致.是计算机广泛使用的杂

  • Java实现MD5加密及解密的代码实例分享

    基础:MessageDigest类的使用 其实要在Java中完成MD5加密,MessageDigest类大部分都帮你实现好了,几行代码足矣: /** * 对字符串md5加密 * * @param str * @return */ import java.security.MessageDigest; public static String getMD5(String str) { try { // 生成一个MD5加密计算摘要 MessageDigest md = MessageDigest.g

  • Python和GO语言实现的消息摘要算法示例

    常用的消息摘要算法有MD5和SHA,这些算法在python和go的库中都有,需要时候调用下就OK了,这里总结下python和go的实现. 一.python消息摘要示例 代码如下: 复制代码 代码如下: #! /usr/bin/python '''       File      : testHash.py       Author    : Mike       E-Mail    : Mike_Zhang@live.com ''' import hashlib src = raw_input(

  • Java实现DES加密与解密,md5加密以及Java实现MD5加密解密类

    很多时候要对秘要进行持久化加密,此时的加密采用md5.采用对称加密的时候就采用DES方法了 import java.io.IOException; import java.security.MessageDigest; import java.security.SecureRandom; import javax.crypto.Cipher; import javax.crypto.SecretKey; import javax.crypto.SecretKeyFactory; import j

随机推荐