java 中 MD5加密的实例

java 中 MD5加密的实例

前言:

今天我来学习利用JAVA编程,通过MD5来实现加密,同时实现验证用户登录原理。

主要是 过程:

将原文的byte 文件通过 MD5加密完成 后。再将其转化为我们能看懂的密文(MD5生成的byte数据,我们无法识别)

主要代码如下

package techDemo;

import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.util.Scanner;

import org.junit.Test;

import sun.misc.BASE64Encoder;

/**
 * MD5加密算法
 * @author<a href="mailto:953801304@qq.com" rel="external nofollow" >胡龙华</a>
 * @version 2017-5-30 下午1:34:51
 * @fileName MD5.java
 */
public class MD5 {

  public static void main(String[] args) throws Exception {
    MessageDigest md = MessageDigest.getInstance("MD5");
    // 原文:
    String pwd = "12345";
    // digese---得到byte数组 加密后的
    byte b []= md.digest(pwd.getBytes());
    System.out.println(b.length); // 16
    // 再将byte b [] 转化为我们能看的懂 密文

    //第一种方式:BASE64Encoder (要导依赖包)
    BASE64Encoder bd = new BASE64Encoder();
    //密文1:
    String strpwd1 = bd.encode(b);
    System.out.println(strpwd1);

    //第二种方式:自己写代码将byte 数组转化为16进制的并且最后的密文保证长度为32
    String strpwd2 = "";
    for(byte i:b){
      // 将单个字节转化为 16 进制
      String s = Integer.toHexString(i & 0xff);
      // 当i<16时,长度为1加个符号 ,这样可以保证最后为 密文为32
      if(s.length()==1){
        s = s + "0";
      }
      strpwd2 += s;
    }
    System.out.println(strpwd2);
/* 输出结果
    16
    gnzLDuqKcGxMNKFokfhOew==
    827ccbe0ea8a706c4c34a16891f84e7b */
  }

  // 演示模拟用户登录
  @Test
  public void demoLogin()throws Exception{
    // 当用户注册成功时,把用户的密码生成密文和用户名一起保存
    // 登录时,通过把用户输入密码再次生成密文,判断两次密文是否一致来验证用户

    // 假设用户密码是 123456789,先生成密文
    String pwd = "123456789";
    String Mpwd = Md5(pwd);
    Scanner sc = new Scanner(System.in);
    while(true){
      System.out.println("请输入密码");
      String p = sc.nextLine();
      if(Mpwd.equals( Md5(p))){
        System.out.println("密码正确");
        break;
      }else{
        System.out.println("密码错误,请重新输入");
      }

    }
  }

  private String Md5(String pwd) throws NoSuchAlgorithmException {
    String Mpwd ="";
    MessageDigest md = MessageDigest.getInstance("MD5");
    byte b [] = md.digest(pwd.getBytes());
    for(byte i:b){
      String s = Integer.toHexString( i & 0xff);
      if(s.length()==1){
        s = s +"0";
      }
      Mpwd = s + pwd;
    }
    return Mpwd;
  }

}

下面是 我们老师的代码 更加细节

package techDemo;

import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;

import org.junit.Test;

import sun.misc.BASE64Encoder;

public class Md5Demo {
  //加密算法类java.security.MessageDigest
  @Test//md5加密的核心代码
  public void demo1() throws Exception{
    MessageDigest md = MessageDigest.getInstance("MD5");
    String pwd="ewi24343423";
    byte b1[] = pwd.getBytes();
    byte b2[] = md.digest( b1 ); //利用md对象把 明文b1[] 加密成 密文b2[]

    //至此,其实md5加密已经完成,可惜它生成的密文全是字节数据,不是我们通常习惯(看得懂)的16进制的数
    //因此还要进一步处理---见demo2()演示

    System.out.println("len:"+b2.length); //永远是:16 ---md5加密算法中,无论明文数据有多长,密文都是16个字节数据

    for(byte b: b2){
      //System.out.print(b+" ");
      System.out.print((char)b+" ");
    }
    System.out.println();
  }

  @Test//把md5生成的密文转换成我们习惯的方式---与前面相比,怪字符少一些,但还不是16进制
  public void demo2() throws Exception{
    MessageDigest md = MessageDigest.getInstance("MD5");
    String pwd="ewi24343423";
    byte b1[] = pwd.getBytes();
    byte b2[] = md.digest( b1 ); //利用md对象把 明文b1[] 加密成 密文b2[]

    System.out.println("len:"+b2.length); //永远是:16

    BASE64Encoder en = new BASE64Encoder();
    String pwd2 = en.encode(b2);
    System.out.println(pwd2);
  }

  /*
   * demo2()方法的缺点:
   * 1. 密文不是我们最习惯的16进制方式
   * 2. 所使用的类BASE64Encoder在API中没有,意味着该类是没有公开
   *  给我们程序员用的,因此它如果变动了,我们是无话可说的即不稳定的!
   *  ---不在接口中,官方是可以随便更改
   */

  @Test //自己手动写代码,把md5生成的密文转换成 我们最习惯的16进制方式
  public void demo3()throws Exception{
    MessageDigest md = MessageDigest.getInstance("MD5");
    String pwd="e655656w23";
    byte b1[] = pwd.getBytes();
    byte b2[] = md.digest( b1 ); //利用md对象把 明文b1[] 加密成 密文b2[]

    System.out.println("len:"+b2.length); //永远是:16

    //手动写代码,把16个byte数据 转换成 32个 16进制数
    String pwd2="";
    for(byte i: b2){
      String s = Integer.toHexString(i & 0xff); //如果i<16则s只有一位,只有>=16的i转换成的s才是两位
      if(s.length()==1){
        s ="0"+s; // s ="f"+s;
      }
      pwd2 +=s;
    }
    pwd2 = pwd2.toUpperCase();
    System.out.println(pwd2.length());
    System.out.println(pwd2);
  }

}

如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

(0)

相关推荐

  • JAVA简单实现MD5注册登录加密实例代码

    开发环境:jdk1.7,eclipse 框架:springmvc,mybatis 工具:maven 以下代码复制即可实现MD5加密 创建一个mave项目,加web.不懂得可以搜索一下就有了. 注册用户的JSP页面代码如下. <%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%> <!DOCTYPE html PU

  • 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加密算法的简单实例

    java 实现MD5加密算法的简单实例 实现代码: import java.security.NoSuchAlgorithmException; public class MD5HashUtil { private MessageDigest md = null; private static MD5HashUtil md5 = null; private static final char[] hexChars ={'0','1','2','3','4','5','6','7','8','9'

  • Java后端实现MD5加密的方法

    前言 在我们开发是要考虑这个功能,当用户忘记密码的情况下,我们需要动态的发给他一个6位的随机密码,通过即时通,短信,微信等.并同时修改数据库中的原密码为这6位的随机密码.让用户再去修改密码. 同时在数据库中的密码必须存为密文,于是需要使用到MD5加密.生成的6位随机密码需要保密,不能在前台处理,只能放在后端.于是我选择放在了控制层中 示例代码 //传入任何需要加密的文本进行加密 public static String getMd5(String string) { try { MessageD

  • java,android,MD5加密算法的实现代码(16位,32位)

    如下所示: import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; public class Md5 { public static String getMD5(String val) throws NoSuchAlgorithmException{ MessageDigest md5 = MessageDigest.getInstance("MD5"); md5.update

  • 基于Java语言MD5加密Base64转换方法

    本文提供了基于MD5加密16位和32位的方法,具体内容如下 import java.io.IOException; import java.math.BigInteger; import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; import sun.misc.BASE64Decoder; import sun.misc.BASE64Encoder; /** * <p>标题:编码工具类

  • java编程下字符串的16位,32位md5加密实现方法

    如下所示: package cn.sunzn.md5; import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; public class Str2MD5 { public static void main(String[] args) { MD5("sunzn"); } private static String MD5(String sourceStr) { String r

  • java MD5加密实现代码

    先从下面这张图对MD5加密实现进行了解,具体如下 package com.pb; import java.io.UnsupportedEncodingException; import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; import java.util.Scanner; /* * 验证MD5 * 1.初始化MessageDigest信息摘要对象 * 2.传入需要计算的字符串更新摘

  • java 中 MD5加密的实例

    java 中 MD5加密的实例 前言: 今天我来学习利用JAVA编程,通过MD5来实现加密,同时实现验证用户登录原理. 主要是 过程: 将原文的byte 文件通过 MD5加密完成 后.再将其转化为我们能看懂的密文(MD5生成的byte数据,我们无法识别) 主要代码如下 package techDemo; import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; import java.ut

  • JAVA中AES加密方法实例分析

    本文实例讲述了JAVA中AES加密方法.分享给大家供大家参考.具体如下: java代码: KeyGenerator kg = KeyGenerator.getInstance("AES"); //获取密匙生成器 kg.init(256); //初始化 //DES算法必须是56位 //DESede算法可以是112位或168位 //AES算法可以是128.192.256位 SecretKey key = kg.generateKey(); //生成密匙,可用多种方法来保存密匙 加密: Ci

  • Java实现MD5加密的方式与实例代码

    1.什么是MD5 MD5加密全程是Message-Digest Algoorithm 5(信息-摘要算法),它对信息进行摘要采集,再通过一定的位运算,最终获取加密后的MD5字符串. 例如我们要加密一篇文章,那么我们会随机从每段话或者每行中获取一个字,把这些字统计出来后,再通过一定的运算获得一个固定长度的MD5加密后信息.因此,其很难被逆向破解. 2.MD5有哪些特点 MD5加密的特点主要有以下几点: 1.针对不同长度待加密的数据.字符串等等,其都可以返回一个固定长度的MD5加密字符串.(通常32

  • 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

  • Winform中进行MD5加密的实例

    Winform,c#进行MD5加密直接上步骤: 1. 添加引用 2. 在.NET选项卡中找到"System.Web" 3. 选中之后,点击"确定"即可,此时会在解决方案中看到刚才添加的引用 4. 引用名空间:using System.Web.Security; Click事件中的代码如下: 还有一种方法: 引用 using System.Security.Cryptography; using System.Text; 具体代码如下(写在按钮的Click事件里):

  • Java实现MD5加密的方法

    本文实例讲述了Java实现MD5加密的方法.分享给大家供大家参考.具体实现方法如下: import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; public class MD5HashUtil { private MessageDigest md = null; private static MD5HashUtil md5 = null; private static final char

  • Java中RSA加密解密的实现方法分析

    本文实例讲述了Java中RSA加密解密的实现方法.分享给大家供大家参考,具体如下: public static void main(String[] args) throws Exception { // TODO Auto-generated method stub HashMap<String, Object> map = RSAUtils.getKeys(); //生成公钥和私钥 RSAPublicKey publicKey = (RSAPublicKey) map.get("

  • C#与java TCP通道加密通信实例

    目录 1.背景说明 2.测试证书 3.复制粘贴加密算法 4.证书格式转换 5.PS1 RSA证书格式 6.参考博文 1.背景说明 公司收费系统需要与银行做实时代收对接,业务协议使用我们收费系统的标准.但是银行要求在业务协议的基础上,使用银行的加密规则. 采用MD5计算报文摘要,保证数据的完整性 采用RSA256对摘要进行签名,保证报文的合法性 采用AES进行对称加密,保证报文的私密性 我们几个人一评估,在业务报文上加一套加密方案,加密方法又是通用的,这个能有什么问题,没问题. 2.测试证书 银行

  • 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

  • java实现MD5加密的方法小结

    本文实例讲述了java实现MD5加密的方法.分享给大家供大家参考,具体如下: private String getMD5Str(String str) { MessageDigest messageDigest = null; try { messageDigest = MessageDigest.getInstance("MD5"); messageDigest.reset(); messageDigest.update(str.getBytes("UTF-8")

随机推荐