⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 md5_java.java

📁 md5算法的java源代码
💻 JAVA
📖 第 1 页 / 共 2 页
字号:
public class MD5 
{ 
  /* 
   * A Java implementation of the RSA Data Security, Inc. MD5 Message 
   * Digest Algorithm, as defined in RFC 1321. 
   * Based on the JavaScript implementation of Paul Johnston 
   *      Copyright (C) Paul Johnston 1999 - 2000. 
   *      See http://pajhome.org.uk/site/legal.html for details. 
   * Java Version by Thomas Weber (Orange Interactive GmbH) 
   */ 
   
  /* 
   * Convert a 32-bit number to a hex string with ls-byte first 
   */ 
  String hex_chr = "0123456789abcdef"; 
  private String rhex(int num) 
  { 
    String str = ""; 
    for(int j = 0; j <= 3; j++) 
      str = str + hex_chr.charAt((num >> (j * 8 + 4)) & 0x0F) + hex_chr.charAt((num >> (j * ) & 0x0F); 
    return str; 
  } 
   
  /* 
   * Convert a string to a sequence of 16-word blocks, stored as an array. 
   * Append padding bits and the length, as described in the MD5 standard. 
   */ 
  private int[] str2blks_MD5(String str) 
  { 
    int nblk = ((str.length() +  >> 6) + 1; 
    int[] blks = new int[nblk * 16]; 
    int i = 0; 
    for(i = 0; i < nblk * 16; i++) { 
      blks[i] = 0; 
    } 
    for(i = 0; i < str.length(); i++) { 
      blks[i >> 2] |= str.charAt(i) << ((i % 4) * ; 
    } 
    blks[i >> 2] |= 0x80 << ((i % 4) * ; 
    blks[nblk * 16 - 2] = str.length()*8; 
       
    return blks; 
  } 
   
  /* 
   * Add integers, wrapping at 2^32 
   */ 
  private int add(int x, int y) 
  { 
    return ((x&0x7FFFFFFF) + (y&0x7FFFFFFF)) ^ (x&0x80000000) ^ (y&0x80000000); 
  } 
   
  /* 
   * Bitwise rotate a 32-bit number to the left 
   */ 
  private int rol(int num, int cnt) 
  { 
    return (num << cnt) | (num >>> (32 - cnt)); 
  } 
   
  /* 
   * These functions implement the basic operation for each round of the 
   * algorithm. 
   */ 
  private int cmn(int q, int a, int b, int x, int s, int t) 
  { 
    return add(rol(add(add(a, q), add(x, t)), s), b); 
  } 
  private int ff(int a, int b, int c, int d, int x, int s, int t) 
  { 
    return cmn((b & c) | ((~b) & d), a, b, x, s, t); 
  } 
  private int gg(int a, int b, int c, int d, int x, int s, int t) 
  { 
    return cmn((b & d) | (c & (~d)), a, b, x, s, t); 
  } 
  private int hh(int a, int b, int c, int d, int x, int s, int t) 
  { 
    return cmn(b ^ c ^ d, a, b, x, s, t); 
  } 
  private int ii(int a, int b, int c, int d, int x, int s, int t) 
  { 
    return cmn(c ^ (b | (~d)), a, b, x, s, t); 
  } 
   
  /* 
   * Take a string and return the hex representation of its MD5. 
   */ 
  public String calcMD5(String str) 
  { 
    int[] x = str2blks_MD5(str); 
    int a = 0x67452301; 
    int b = 0xEFCDAB89; 
    int c = 0x98BADCFE; 
    int d = 0x10325476; 
   
    for(int i = 0; i < x.length; i += 16) 
    { 
      int olda = a; 
      int oldb = b; 
      int oldc = c; 
      int oldd = d; 
   
      a = ff(a, b, c, d, x[i+ 0], 7 , 0xD76AA47; 
      d = ff(d, a, b, c, x[i+ 1], 12, 0xE8C7B756); 
      c = ff(c, d, a, b, x[i+ 2], 17, 0x242070DB); 
      b = ff(b, c, d, a, x[i+ 3], 22, 0xC1BDCEEE); 
      a = ff(a, b, c, d, x[i+ 4], 7 , 0xF57C0FAF); 
      d = ff(d, a, b, c, x[i+ 5], 12, 0x4787C62A); 
      c = ff(c, d, a, b, x[i+ 6], 17, 0xA8304613); 
      b = ff(b, c, d, a, x[i+ 7], 22, 0xFD469501); 
      a = ff(a, b, c, d, x[i+ 8], 7 , 0x698098D; 
      d = ff(d, a, b, c, x[i+ 9], 12, 0x8B44F7AF); 
      c = ff(c, d, a, b, x[i+10], 17, 0xFFFF5BB1); 
      b = ff(b, c, d, a, x[i+11], 22, 0x895CD7BE); 
      a = ff(a, b, c, d, x[i+12], 7 , 0x6B901122); 
      d = ff(d, a, b, c, x[i+13], 12, 0xFD987193); 
      c = ff(c, d, a, b, x[i+14], 17, 0xA679438E); 
      b = ff(b, c, d, a, x[i+15], 22, 0x49B40821); 
   
      a = gg(a, b, c, d, x[i+ 1], 5 , 0xF61E2562); 
      d = gg(d, a, b, c, x[i+ 6], 9 , 0xC040B340); 
      c = gg(c, d, a, b, x[i+11], 14, 0x265E5A51); 
      b = gg(b, c, d, a, x[i+ 0], 20, 0xE9B6C7AA); 
      a = gg(a, b, c, d, x[i+ 5], 5 , 0xD62F105D); 
      d = gg(d, a, b, c, x[i+10], 9 , 0x02441453); 
      c = gg(c, d, a, b, x[i+15], 14, 0xD8A1E681); 
      b = gg(b, c, d, a, x[i+ 4], 20, 0xE7D3FBC; 
      a = gg(a, b, c, d, x[i+ 9], 5 , 0x21E1CDE6); 
      d = gg(d, a, b, c, x[i+14], 9 , 0xC33707D6); 
      c = gg(c, d, a, b, x[i+ 3], 14, 0xF4D50D87); 
      b = gg(b, c, d, a, x[i+ 8], 20, 0x455A14ED); 
      a = gg(a, b, c, d, x[i+13], 5 , 0xA9E3E905); 
      d = gg(d, a, b, c, x[i+ 2], 9 , 0xFCEFA3F; 
      c = gg(c, d, a, b, x[i+ 7], 14, 0x676F02D9); 
      b = gg(b, c, d, a, x[i+12], 20, 0x8D2A4C8A); 
   
      a = hh(a, b, c, d, x[i+ 5], 4 , 0xFFFA3942); 
      d = hh(d, a, b, c, x[i+ 8], 11, 0x8771F681); 
      c = hh(c, d, a, b, x[i+11], 16, 0x6D9D6122); 
      b = hh(b, c, d, a, x[i+14], 23, 0xFDE5380C); 
      a = hh(a, b, c, d, x[i+ 1], 4 , 0xA4BEEA44); 
      d = hh(d, a, b, c, x[i+ 4], 11, 0x4BDECFA9); 
      c = hh(c, d, a, b, x[i+ 7], 16, 0xF6BB4B60); 
      b = hh(b, c, d, a, x[i+10], 23, 0xBEBFBC70); 
      a = hh(a, b, c, d, x[i+13], 4 , 0x289B7EC6); 
      d = hh(d, a, b, c, x[i+ 0], 11, 0xEAA127FA); 
      c = hh(c, d, a, b, x[i+ 3], 16, 0xD4EF3085); 
      b = hh(b, c, d, a, x[i+ 6], 23, 0x04881D05); 
      a = hh(a, b, c, d, x[i+ 9], 4 , 0xD9D4D039); 
      d = hh(d, a, b, c, x[i+12], 11, 0xE6DB99E5); 
      c = hh(c, d, a, b, x[i+15], 16, 0x1FA27CF; 
      b = hh(b, c, d, a, x[i+ 2], 23, 0xC4AC5665); 
   
      a = ii(a, b, c, d, x[i+ 0], 6 , 0xF4292244); 
      d = ii(d, a, b, c, x[i+ 7], 10, 0x432AFF97); 
      c = ii(c, d, a, b, x[i+14], 15, 0xAB9423A7); 
      b = ii(b, c, d, a, x[i+ 5], 21, 0xFC93A039); 
      a = ii(a, b, c, d, x[i+12], 6 , 0x655B59C3); 
      d = ii(d, a, b, c, x[i+ 3], 10, 0x8F0CCC92); 
      c = ii(c, d, a, b, x[i+10], 15, 0xFFEFF47D); 
      b = ii(b, c, d, a, x[i+ 1], 21, 0x85845DD1); 
      a = ii(a, b, c, d, x[i+ 8], 6 , 0x6FA87E4F); 
      d = ii(d, a, b, c, x[i+15], 10, 0xFE2CE6E0); 
      c = ii(c, d, a, b, x[i+ 6], 15, 0xA3014314); 
      b = ii(b, c, d, a, x[i+13], 21, 0x4E0811A1); 
      a = ii(a, b, c, d, x[i+ 4], 6 , 0xF7537E82); 
      d = ii(d, a, b, c, x[i+11], 10, 0xBD3AF235); 
      c = ii(c, d, a, b, x[i+ 2], 15, 0x2AD7D2BB); 
      b = ii(b, c, d, a, x[i+ 9], 21, 0xEB86D391); 
   
      a = add(a, olda); 
      b = add(b, oldb); 
      c = add(c, oldc); 
      d = add(d, oldd); 
    } 
    return rhex(a) + rhex(b) + rhex(c) + rhex(d); 
  } 

}

 
 
【发表回复】【查看CU论坛原帖】【关闭】  

--------------------------------------------------------------------------------
 ii 回复于:2003-01-28 13:51:46 
另:  一中国人写的md5 的javabean: 

/************************************************ 
MD5 算法的Java Bean 
@author:Topcat Tuppin 
Last Modified:10,Mar,2001 
*************************************************/ 
//package beartool; 
import java.lang.reflect.*; 
/************************************************* 
md5 类实现了RSA Data Security, Inc.在提交给IETF 
的RFC1321中的MD5 message-digest 算法。 
*************************************************/ 

public class MD5 { 
/* 下面这些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 < 16; i++) { 
                        digestHexStr += byteHEX(digest[i]); 
                } 
                return digestHexStr; 

        } 
        // 这是MD5这个类的标准构造函数,JavaBean要求有一个public的并且没有参数的构造函数 
        public MD5() { 
                md5Init(); 

                return; 
        } 
         


        /* md5Init是一个初始化函数,初始化核心变量,装入标准的幻数 */ 
        private void md5Init() { 
                count[0] = 0L; 
                count[1] = 0L; 
                ///* Load magic initialization constants. 

                state[0] = 0x67452301L; 
                state[1] = 0xefcdab89L; 
                state[2] = 0x98badcfeL; 
                state[3] = 0x10325476L; 

                return; 
        } 
        /* F, G, H ,I 是4个基本的MD5函数,在原始的MD5的C实现中,由于它们是 
        简单的位运算,可能出于效率的考虑把它们实现成了宏,在java中,我们把它们 
       实现成了private方法,名字保持了原来C中的。 */ 

        private long F(long x, long y, long z) { 
                return (x & y) | ((~x) & z); 

        } 
        private long G(long x, long y, long z) { 
                return (x & z) | (y & (~z)); 

        } 
        private long H(long x, long y, long z) { 
                return x ^ y ^ z; 
        } 

        private long I(long x, long y, long z) { 
                return y ^ (x | (~z)); 
        } 
         
       /*  
          FF,GG,HH和II将调用F,G,H,I进行近一步变换 
          FF, GG, HH, and II transformations for rounds 1, 2, 3, and 4. 
          Rotation is separate from addition to prevent recomputation. 
       */   

        private long FF(long a, long b, long c, long d, long x, long s, 

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -