信息加密之信息摘要加密MD2、MD4、MD5

   对于用户数据的保密一直是各个互联网企业头疼的事,那如何防止用户的个人信息泄露呢?今天为大家介绍一种最简单的加密方式--信息摘要算法MD。它如何来保护用户的个人信息呢?其实很简单,当获得到用户的信息后,先对其进行加密,然后将加密的结果保存到数据库,这样即使被盗,用户的数据也不会丢失。下面上代码:

  JAVA的jdk提供了MD2和MD5的加密方式, JAVA不支持MD4的jdk加密方式,jdk的实现如下:

private static void MD2_jdk(){
        try {
            MessageDigest digest = MessageDigest.getInstance("MD2");//获得消息摘要MD2对象
            byte[] md2Byte = digest.digest(src.getBytes());
            System.out.println("md2Byte :"+md2Byte.toString());
            System.out.println("md2Byte :"+Hex.encodeHexString(md2Byte));
        } catch (NoSuchAlgorithmException e) {
            e.printStackTrace();
        }
    }

    private static void MD5_jdk(){
        try {
            MessageDigest digest = MessageDigest.getInstance("MD5");//获得消息摘要MD5对象
            byte[] md5Byte = digest.digest(src.getBytes());
            System.out.println("md5Byte :"+md5Byte.toString());
            System.out.println("md5Byte :"+Hex.encodeHexString(md5Byte));
        } catch (NoSuchAlgorithmException e) {
            e.printStackTrace();
        }
    }

  bc提供了MD2\4\5的加密实现(bc使用需要添加bc的jar包):

private static void MD2_bc(){
        Digest digest = new MD2Digest();//通过BC获得消息摘要MD2对象
        digest.update(src.getBytes(), 0, src.getBytes().length);
        byte[] md2Byte = new byte[digest.getDigestSize()];
        digest.doFinal(md2Byte, 0);
        System.out.println("md2Byte :"+md2Byte.toString());
        System.out.println("md2Byte : "+org.bouncycastle.util.encoders.Hex.toHexString(md2Byte));
    }

    private static void MD4_bc(){
        Digest digest = new MD4Digest();//通过BC获得消息摘要MD4对象
        digest.update(src.getBytes(), 0, src.getBytes().length);
        byte[] md4Byte = new byte[digest.getDigestSize()];
        digest.doFinal(md4Byte, 0);
        System.out.println("md4Byte :"+md4Byte.toString());
        System.out.println("md4Byte : "+org.bouncycastle.util.encoders.Hex.toHexString(md4Byte));
    }

    private static void MD5_bc(){
        Digest digest = new MD5Digest();//通过BC获得消息摘要MD5对象
        digest.update(src.getBytes(), 0, src.getBytes().length);
        byte[] md5Byte = new byte[digest.getDigestSize()];
        digest.doFinal(md5Byte, 0);
        System.out.println("md5Byte :"+md5Byte.toString());
        System.out.println("md5Byte : "+org.bouncycastle.util.encoders.Hex.toHexString(md5Byte));
    }

  通过bc为jdk添加一个动态的MD4方法:

private static void MD4_bc_jdk(){
        try {
            Security.addProvider(new BouncyCastleProvider());
            MessageDigest md = MessageDigest.getInstance("MD4");
            byte[] md4Byte = md.digest(src.getBytes());
            System.out.println("md4Byte :"+md4Byte.toString());
            System.out.println("md4Byte :"+Hex.encodeHexString(md4Byte));
        } catch (NoSuchAlgorithmException e) {
            e.printStackTrace();
        }
    }

  最后为大家介绍一下CC的MD2\5的实现:

DigestUtils.md2Hex(src.getBytes());
DigestUtils.md5Hex(src.getBytes());

注:src为设置的一个字符串。

  到这里消息摘要加密算法的MD2\4\5的实现到此讲解完毕,对Base64和对称加密算法有兴趣的朋友可以看一下我之前分享的博客。小生很喜欢信息安全,那位有兴趣,欢迎交流。([email protected])

时间: 2024-07-28 20:49:44

信息加密之信息摘要加密MD2、MD4、MD5的相关文章

网络安全-安全散列函数,信息摘要SHA-1,MD5原理

-----------------------------------------------欢迎查看网络安全连载博客-----------------------------------[网络安全]-安全散列函数.信息摘要SHA-1.MD5算法       [网络安全]-非对称加密,RSA算法,数字签名[网络安全]-RSA非对称算法算法.数字签名                         [网络安全]-建立安全socket连接.登录[网络安全]-[数字证书,证书链]-----------

C/C++使用openssl进行摘要和加密解密(md5, sha256, des, rsa)

openssl里面有很多用于摘要哈希.加密解密的算法,方便集成于工程项目,被广泛应用于网络报文中的安全传输和认证.下面以md5,sha256,des,rsa几个典型的api简单使用作为例子. 算法介绍 md5:https://en.wikipedia.org/wiki/MD5 sha256:https://en.wikipedia.org/wiki/SHA-2 des: https://en.wikipedia.org/wiki/Data_Encryption_Standard rsa: htt

09.openssl信息摘要和数字签名指令

9.1 信息摘要算法和数字签名 信息摘要算法是现代密码学算法中不可缺少的一部分,与对称算法和非对称加密算法不同,他不是一种可逆的操作,经过它进行处理的数据,输出数据长度一般来说总是固定的,并且理论上很难从输出恢复输入. 数字签名操作一般采用非对称算法(公开密钥算法),其实质是使用费对称加密算法密钥对的私钥对数据进行加密,而数字签名的验证操作则是使用公钥对数据进行解密操作,然后比较得到的原始文件跟解密得到的文件信息是否一致,如果一致,则认为数字签名有效,从而确认文件的有效性. 指令 指令功能描述

JavaScript加密库jQuery.md5.js

JavaScript简单的MD5加密库jQuery.md5.js,简单用法如下: //Create (hex-encoded) MD5 hash of a given string value: var md5 = $.md5('value'); //Create (hex-encoded) HMAC-MD5 hash of a given string value and key: var md5 = $.md5('value', 'key'); //Create raw MD5 hash o

DES对称加解密、AES RijndaelManaged加解密、Base64加密解密、MD5加密等操作辅助类 EncodeHelper

/// <summary> /// 使用默认加密 /// </summary> /// <param name="strText"></param> /// <returns></returns> public static string DesEncrypt(string strText) /// <summary> /// 使用默认解密 /// </summary> /// <pa

加密与解密md5 3des

/// <summary> /// MD5加密 /// </summary> /// <param name="s"></param> /// <returns></returns> public static string MD5Encrypt(string s) { string strResult = ""; System.Security.Cryptography.MD5 md5 = S

Python 生成随机数函数和加密函数(MD5)

内容来自debugtalk import hashlib import random import string def gen_random_string(str_len): '''生成指定长度的随机数函数''' return ''.join( random.choice(string.ascii_letters + string.digits) for _ in range(str_len)) def gen_md5(*args): '''MD5加密''' return hashlib.md

java 加密解密算法MD5/SHA1,DSA

通常,使用的加密算法 比较简便高效,密钥简短,加解密速度快,破译极其困难.本文介绍了 MD5/SHA1,DSA,DESede/DES,Diffie-Hellman的使用. 第1章基础知识 1.1. 单钥密码体制 单钥密码体制是一种传统的加密算法,是指信息的发送方和接收方共同使用同一把密钥进行加解密. 通常,使用的加密算法比较简便高效,密钥简短,加解密速度快,破译极其困难.但是加密的安全性依靠密钥保管的安全性,在公开的计算机网络上安全地传送和保管密钥是一个严峻的问题,并且如果在多用户的情况下密钥的

SHA信息摘要

SHA算法是在MD4的基础上演进而来的,通过SHA算法能够获得一个固定长度的摘要信息. SHA算法系列有SHA-1(也成为SHA),SHA-224,SHA-256,SHA-384和SHA-512这五种算法,通常后面四中算法并称为SHA-2算法,它们都是以长度来命名的. SHA与MD算法的不同之处主要在于摘要长度,SHA算法的摘要长度更长,安全性更高 SHA算法的长度说明 SHA算法实现(类似MD5的实现) 1.Java自带的MessageDigest类 注意:仅支持SHA-1,SHA-256,S