MD5算法的简要叙述为:

MD5以512位分组来处理输入的信息(512位分组?每次处理都取出512位数据?),

每一分组又被划分为16个32位子分组(16乘32刚好是512),

经过一些列的处理后(怎么处理的?),算法的输出由四个32位分组组成,

将这4个32位分组级联后将生成一个128位的散列值(那么这个散列值是最后的加密结果咯)。

在MD5算法中,首先需要对信息进行填充,使其位长度对512求余的结果等于448。

因此,信息的位长度(Bits Length)将被扩展至N*512+448,即N*64+56个字节(Bytes),N是一个正整数。

填充方法如下:

在信息的后面填一个和无数个0,直到满足上面的条件时才停止用0对信息的填充。然后,在这个结果后面附加一个以64位二进制表示的填充前信息长度。

(这里的信息长度应该是位长度吧?)。经过这两步的处理,现在的信息字节长度=N*512+448+64=(N+1)*512,即长度恰好是512的整数倍。

这样也是为了满足后面处理中对信息长度的要求。

MD5中有4个32为被称为链接变量(Chaining Variable)的整数参数,它们分别是:

A=0x01234567,

B=0x89abcdef,

C=0xfedcba98,

D=0x76543210,

(这四个数是大端法表示的!每一个变量给出的数值是高字节存于内存低地址,低字节存于内存高地址,即大端字节序。

在程序中变量A、B、C、D的值分别为0x67452301,0xEFCDAB89,0x98BADCFE,0x10325476,马丹,这里有点搞不清白)

当设置好这四个链接变量之后,就开始进入算法的四轮循环运算。循环的次数是信息中512位信息分组的数目。

(也就是说经过填充之后的数据位数是512的整数倍,然后按照顺序每次取出512位拿过来进行四轮处理)

将上面4个链接变量复制到另外4个变量中:A到a,B到b,C到c,D到d。

主循环有四轮(MD4只有三轮,三轮车?),每轮循环都很相似。

第一轮进行16次操作。每次操作对a、b、c和d中的3个做一次非线性函数运算,然后将所得的结果依次加上第四个变量、文本的一个子分组和一个常数。

再将所得的结果向右循环移动一个不定的数,并加上a、b、c或d中之一。最后用该结果取代a、b、c或d中之一。

下面是每次操作中用到的四个非线性函数(每轮一个)。

F(X, Y, Z) = (X & Y) | ((~X) & Z)

G(X, Y, Z) = (X  & Z) | (Y & (~Z))

H(X, Y, Z) = X^Y^Z

I(X, Y, Z) = Y^(X | (~Z))

(&是与,|是或,~是非,^是异或)

这四个函数的说明:如果X、Y和Z的对应位是独立和均匀的,那么结果的每一位也应是独立和均匀的。

F是一个逐位运算的函数。即,如果X,那么Y,否则Z。

H是逐位奇偶操作符。

假设Mj表示消息的第j个子分组(从0到15),

FF(a, b, c, d, Mj, s, ti)表示a = b + ((a + F(b, c, d) + Mj + ti) << s),

GG(a, b, c, d, Mj, s, ti)表示a = b + ((a + G(b, c, d) + Mj + ti) << s),

HH(a, b, c, d, Mj, s, ti)表示a = b + ((a + H(b, c, d) + Mj + ti) << s),

II(a, b, c, d, Mj, s, ti)表示a = b + ((a + I(b, c, d) + Mj + ti) << s),

(尼玛,这几个看着倒是挺对称的)

(<<是循环左移位,而不是左移位)

这四轮(一轮16步,取32位数处理,一共64步)是:

第一轮

第二轮

第三轮

第四轮

常数ti可以如下选择:

在第i步中,ti是4294967296*abs(sin(i))的整数部分,i的单位是弧度(4294967296等于2的32次方)。

在所有的这些都完成之后,将A、B、C、D分别加上a、b、c、d。然后用下一分组数据继续运行算法,最后的输出将是A、B、C和D的级联。

在Java中,java。security.MessageDigest中已经定义了MD5的计算,只需要简单地调用即可得到MD5的128位整数。

然后将此128位(16个字节)转换成十六进制表示即可。

package com.java.md5;

public class MD5 {
public static String getMD5(byte[] source) {
String s = null;
char hexDigits[] = {'0','1','2','3','4','5','6','7','8','9','a',
'b','c','d','e','f'};
try {
java.security.MessageDigest md =
java.security.MessageDigest.getInstance("MD5");
md.update(source);
byte tmp[] = md.digest();
char str[] = new char[16*2];
int k = 0;
for (int i = 0; i < 16; i++) {
byte byte0 = tmp[i];
str[k++] = hexDigits[byte0 >>> 4 & 0xf];
str[k++] = hexDigits[byte0 & 0xf];
}
s = new String(str);
} catch(Exception e) {
e.printStackTrace();
}
return s;
} public static void main(String[] args) {
String a = "I love you";
byte[] b = a.getBytes();
for (int i=0; i<b.length; i++)
System.out.print(b[i] + " ");
String str = MD5.getMD5(b);
System.out.println("a = " + a + "\n" + "str = " + str + "\n");
}
}

MD5算法实现的更多相关文章

  1. md5算法

    md5算法 不可逆的:原文-->密文.用系统的API可以实现: 123456 ---密文 1987 ----密文: 算法步骤: 1.用每个byte去和11111111做与运算并且得到的是int类 ...

  2. MD5算法 简介

    MD5(单向散列算法)的全称是Message-Digest Algorithm 5(信息-摘要算法),经MD2.MD3和MD4发展而来.MD5算法的使用不需要支付任何版权费用. MD5功能 l 输入任 ...

  3. md5算法原理一窥(其一)

    首先,需要了解的事,md5并不是传说中的加密算法,只是一种散列算法.其加密的算法并不是我们说所的那样固定不变,只是一种映射的关系. 所以解密MD5没有现成的算法,只能用穷举法,把可能出现的明文,用MD ...

  4. Java利用MessageDigest提供的MD5算法加密字符串或文件

    MD5是常用的加密算法,也经常用于校验信息完整,如文件的完整性.用术语讲,MD5是一种消息摘要算法(Message Digest Algorithm).另外还有一种常用的消息摘要算法SHA1.如果想了 ...

  5. python学习笔记(MD5算法)

    博主最近进度停滞了 对web开发理解欠缺好多内容 今天整理下MD5算法,这个涉及到mysql数据库存储用户表密码字段的时候 一般是带有加密的 # -*- coding: utf-8 -*- impor ...

  6. 在MAC平台下编译Ngnix ,由于MD5算法不能编译通过 解决办法

    近期想学习Ngnix 代码,前些日子,对”自己下手狠一次“, 买了MAC 本. 所以想在Mac 上编译,是必须的,不然对不起自己的内心. 不巧遇到了MD5算法编译的问题 src/core/ngx_cr ...

  7. MD5算法步骤详解

    转自MD5算法步骤详解 之前要写一个MD5程序,但是从网络上看到的资料基本上一样,只是讲了一个大概.经过我自己的实践,我决定写一个心得,给需要实现MD5,但又不要求很高深的编程知识的童鞋参考.不多说了 ...

  8. Java 实现Md5算法

    package other; import java.security.MessageDigest;import java.security.NoSuchAlgorithmException;/* * ...

  9. MD5算法【计算文件和字符串的MD5值】

    1. MD5算法是一种散列(hash)算法(摘要算法,指纹算法),不是一种加密算法(易错).任何长度的任意内容都可以用MD5计算出散列值.MD5的前身:MD2.MD3.MD4.介绍工具:CalcMD5 ...

  10. 经常使用MD5算法代码

    经常使用的MD5算法代码日期: 2014年8月4日作者: 铁锚 MD5,全称为 Message Digest Algorithm 5(消息摘要算法第五版).详情请參考 维基百科:MD5  MD5加密后 ...

随机推荐

  1. Google Volley框架之https请求

    先插一句.Google出的volley框架本身是支持https请求的,可是仅仅是针对有第三方机构认证过的. 假设自己随便在网上搞的一个证书,那volley是不支持请求的. 本文讲下怎样让volley支 ...

  2. jquery serialize对json的包装用法

    jquery对象.serialize()  可以多用于表单对数据封装提交 能够收表参数,形成一个json格式字符串, 前提是:必须为每一个表单项取一个name属性 对元素 设置 name属性, 然后 ...

  3. C# 调节图片亮度

    原文地址:https://www.cnblogs.com/wjr408/p/6727118.html 昨天去客户那里测试,需求才开始,所以很简单,就是测一下能不能接受到视频或图片,然后保存下来,现场客 ...

  4. Python学习笔记015——readline与readlines的区别

    示例1 读取同样一个文件binary_read_1.txt. 春眠不觉晓,处处闻啼鸟. 夜来风雨声,花落知多少. 其中该文件内容被下段代码读出(注意,这里是采用的readlines) f = open ...

  5. Python学习笔记012——装饰器

    1 装饰器 1.1装饰器定义 在代码运行期间动态增加功能的方式,称之为“装饰器”(Decorator). 1.2 装饰器分类 装饰器:函数装饰器,类装饰器,函数的装饰器,类的装饰器 装饰器:函数装饰函 ...

  6. 一个进程发起多个连接和gethostbyname等函数

    一.在前面讲过的最简单的回射客户/服务器程序中,一个客户端即一个进程,只会发起一个连接,只要稍微修改一下就可以让一个客户端发起多个连 接,然后只利用其中一个连接发送数据. 先来认识一个函数getsoc ...

  7. cocos2dx 3.1从零学习(五)——动画

    动画是游戏中最重要的表现部分,本篇仅仅是初步学习大部分动画的用法.没有什么原理性的东西,可是样例有非常多,假设有不熟的地方要练一下. 特别是Spawn和Sequence的组合使用,什么时候使用Spaw ...

  8. es6 generator 基础知识

    1.定义和使用 function *gen() { return 'first generator'; } // 有点类似类的实例化过程 let generatorResult = gen() // ...

  9. django的hello world 项目

    一.新建一个django项目bester: django-admin startproject bester 二.在bester项目中建一个叫polls的应用程序: cd bester/ python ...

  10. Netty(六):Netty中的连接管理(心跳机制和定时断线重连)

    何为心跳 顾名思义, 所谓心跳, 即在TCP长连接中, 客户端和服务器之间定期发送的一种特殊的数据包, 通知对方自己还在线, 以确保 TCP 连接的有效性. 为什么需要心跳 因为网络的不可靠性, 有可 ...