免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 828 | 回复: 0
打印 上一主题 下一主题

MD5算法 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-01-23 21:34 |只看该作者 |倒序浏览

package com.zhaisx.myssh.util;
/************************************************
MD5 算法的Java Bean
Last Modified:10,Mar,2001
*************************************************/
/*******************************************************************************
* md5 类实现了RSA Data Security, Inc.在提交给IETF 的RFC1321中的MD5 message-digest 算法。
******************************************************************************/
public class MD5Code {
/*
  * 下面这些S11-S44实际上是一个4*4的矩阵,在原始的C实现中是用#define 实现的, 这里把它们实现成为static
  * final是表示了只读,切能在同一个进程空间内的多个 Instance间共享
  */
static final int S11 = 7;
static final int S12 = 12;
static final int S13 = 17;
static final int S14 = 22;
static final int S21 = 5;
static final int S22 = 9;
static final int S23 = 14;
static final int S24 = 20;
static final int S31 = 4;
static final int S32 = 11;
static final int S33 = 16;
static final int S34 = 23;
static final int S41 = 6;
static final int S42 = 10;
static final int S43 = 15;
static final int S44 = 21;
static final byte[] PADDING = { -128, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
   0, 0, 0, 0, 0, 0, 0 };
/*
  * 下面的三个成员是MD5计算过程中用到的3个核心数据,在原始的C实现中 被定义到MD5_CTX结构中
  */
private long[] state = new long[4];// state (ABCD)
private long[] count = new long[2];// number of bits, modulo 2^64 (lsb
// first)
private byte[] buffer = new byte[64]; // input buffer
/*
  * digestHexStr是MD5的唯一一个公共成员,是最新一次计算结果的 16进制ASCII表示.
  */
public String digestHexStr;
/*
  * digest,是最新一次计算结果的2进制内部表示,表示128bit的MD5值.
  */
private byte[] digest = new byte[16];
/*
  * getMD5ofStr是类MD5最主要的公共方法,入口参数是你想要进行MD5变换的字符串
  * 返回的是变换完的结果,这个结果是从公共成员digestHexStr取得的.
  */
public String getMD5ofStr(String inbuf) {
  md5Init();
  md5Update(inbuf.getBytes(), inbuf.length());
  md5Final();
  digestHexStr = "";
  for (int i = 0; i >> (32 - s));
  a += b;
  return a;
}
private long GG(long a, long b, long c, long d, long x, long s, long ac) {
  a += G(b, c, d) + x + ac;
  a = ((int) a >> (32 - s));
  a += b;
  return a;
}
private long HH(long a, long b, long c, long d, long x, long s, long ac) {
  a += H(b, c, d) + x + ac;
  a = ((int) a >> (32 - s));
  a += b;
  return a;
}
private long II(long a, long b, long c, long d, long x, long s, long ac) {
  a += I(b, c, d) + x + ac;
  a = ((int) a >> (32 - s));
  a += b;
  return a;
}
/*
  * md5Update是MD5的主计算过程,inbuf是要变换的字节串,inputlen是长度,这个
  * 函数由getMD5ofStr调用,调用之前需要调用md5init,因此把它设计成private的
  */
private void md5Update(byte[] inbuf, int inputLen) {
  int i, index, partLen;
  byte[] block = new byte[64];
  index = (int) (count[0] >>> 3) & 0x3F;
  // /* Update number of bits */
  if ((count[0] += (inputLen >> 29);
  partLen = 64 - index;
  // Transform as many times as possible.
  if (inputLen >= partLen) {
   md5Memcpy(buffer, inbuf, index, 0, partLen);
   md5Transform(buffer);
   for (i = partLen; i + 63 >> 3) & 0x3f;
  padLen = (index >> 8) & 0xffL);
   output[j + 2] = (byte) ((input >>> 16) & 0xffL);
   output[j + 3] = (byte) ((input >>> 24) & 0xffL);
  }
}
/*
  * Decode把byte数组按顺序合成成long数组,因为java的long类型是64bit的,
  * 只合成低32bit,高32bit清零,以适应原始C实现的用途
  */
private void Decode(long[] output, byte[] input, int len) {
  int i, j;
  for (i = 0, j = 0; j >> 4) & 0X0F];
  ob[1] = Digit[ib & 0X0F];
  String s = new String(ob);
  return s;
}
}


本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u1/33099/showart_470167.html
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP