精华内容
下载资源
问答
  • MD5修改器.exe

    2017-07-13 03:04:45
    MD5修改
  • MD5修改工具.exe

    2019-07-12 11:20:32
    每一个文件都有自己的文件指纹(MD5值等等相当shenfen证),很多平台会检测文件是否重复(如:1688的详情页图片是否原创检测、百度图片原创筛选、各大视频平台去重等等,他们机器检测MD5发现有与数据库中重复的轻则...
  • 批量修改图片MD5.exe

    2020-10-18 03:08:06
    批量修改图片MD5.exe
  • MD5批量修改.exe

    2020-07-15 13:11:38
    可一键批量修改文件MD5特征 防止被和谐或者特征!
  • MD5自动修改器.exe

    2011-08-04 17:15:20
    好用的MD5自动修改器,抓鸡时配合使用,防止MD5值被杀,抓鸡神器!
  • MD5修改工具3.zip

    2020-04-21 19:30:15
    文件MD5修改器是一款专门用于修改文件MD5数值的小工具。MD5在以前是文件唯一的身份ID,类似于我们的身份证号码一样是唯一的的。但是随着网络的发展已经有人破解出算法。所以我们现在下载文件,也不能只相信MD5了。...
  • 基础方法:打开md5破解,exe输入MD5值,按回车即可 高级方法:用命令行进入md5破解所在目录执行东方黒盟md5破解 <MD5值> <配置文件名> 注意事项:请将本程序放在英文路径下,放在中文路径下可能会出现问题 注意:破解的...
  • 文件MD5批量修改工具
  • MD5change修改

    2013-05-07 20:33:16
    MD5可以为任何文件(不管其大小、格式、数量)产生一个同样独一无二的"数字指纹",如果任何人对文件做了任何改动,其MD5值也就是对应的"数字指纹"都会发生变化。可以通过修改软件的MD5值,躲避杀软的监控.
  • 修改文件MD5

    2018-07-12 15:47:02
    修改文件MD5值,方便上传小视频。修改文件MD5值,方便上传小视频。
  • CRC32: 812B5F0B MD5: 083D2F9752C69339E7B9EC8BCED0AB69 SHA-1: 9FAAFAA5CD8F99E829CA...3、一键修改文件或文件夹内文件md5 4、增加托盘图标 5、优化了修改流程,使修改速度更快 2011-8-17 18:30:59 发布 火眼查毒: ...
  • MD5校验工具.exe

    2019-07-23 13:45:24
    MD5校验工具是用来校验下载的资源是否与官网提供的资源一直,如果校验出来的MD5值与官方提供的MD5值不一致,则说明你下载的文件被修改过,请谨慎使用
  • Fbx转Md5动画exe程序

    2016-12-07 16:13:44
    ●该程序能将fbx动画导出md5骨骼动画,封装的exe程序(非max脚本,非插件). ●输入的fbx和输出的md5坐标系都是采用Z朝上的max坐标(标准Md5坐标系). ●输入的fbx路径和文件名只能是英文,输出路径可为中文. ●数据算法...
  • wampserver服务器用于搭建自己的服务器系统,参数可配,简单易用
  • 修改文件的MD5

    千次阅读 2019-03-14 19:40:55
    原标题是:修改文件MD5 原作者是:筝风放风筝 原文链接是: https://blog.csdn.net/Feng512275/article/details/81431467 这篇文章复制的方法是:在浏览器中审查元素(点F12),复制HTML元素,直接粘贴在此处。 ...

    原文链接: https://blog.csdn.net/Feng512275/article/details/81431467
    本文转载方法:在浏览器中审查元素(F12),复制HTML元素,直接粘贴在此处。
    详见教程:https://blog.csdn.net/qq_34646449/article/details/73844023

    本文亲测有效!上传 Teacher Cang 的视频到某知名限速网盘,会成为一个“净网公告”, 按本文操作,修改文件的MD5,就可以上传了。


    背景

    文件的MD5就像文件的ID一样,唯一标识一个文件。

    MD是Message Digest的缩写,翻译为信息摘要或数字签名。MD5是散列\哈希算法的一种,其他的算法还有SHA系列算法,这种算法能通过文件的信息计算出的一组数字,来唯一标识这个文件,而且是不可逆的,但是一旦文件被篡改,哪怕是一点点,计算出的信息摘要就不一样了。

    某些网站会提供下载软件的MD5,你可以自己通过MD5算法计算并进行对比确定软件有无篡改

    你要发某文本给别人,可以将文本内容MD5计算信息摘要,再将文本内容用你的私钥加密,向别人发送私钥加密文本和MD5摘要,别人得到后,用你的公钥解密文本,自己计算MD5并进行对比,如果一样,就说明没有被篡改。


    MD5的应用

    那么MD5有什么应用呢?

    某盘不是经常河蟹一些视频吗? 那他是怎么做到的呢?
    他不可能所有的视频都看一遍吧,这样太耗费人力了。(当然,也有鉴黄师人工操作的,但毕竟大批量的还是交给电脑来处理的)
    其实就是保存了各个视频的MD5而已,你上传的东西,对比一下他保存的MD5是否一样,如果一样,那简单,直接和谐好了。

    em…清楚了这个原理,那么我就可以搞一波骚操作了,我修改他的MD5,生成一个新的MD5,那某盘就没法识别了。


    修改MD5

    打开CMD命令行,然后进入你要修改的文件所在的文件夹。

    命令:CD xxxx对应的文件夹xx

    在这里插入图片描述
    创建一个新的记事本(名字随便起,上图中我创建的记事本命名为“HZhenF”,内容随便输入一点就好)
    用原视频+HZhenF记事本生成一个新的MD5视频

    格式:copy /b 原视频+txt文件名 新的视频名字
    命令:copy /b 肖生克的救赎.mp4+HZhenF.txt 肖生克的救赎_新文件.mp4

    在这里插入图片描述

    查看文件的MD5
    命令:certutil -hashfile 文件名.后缀 MD5

    在这里插入图片描述

    展开全文
  • md5的方式,对文件进行加密处理,其中生成是md5值,是判断文件是否被修改的重要凭证。
    使用MD5的方式对文件进行加密,判断获取文件是否被修改的唯一凭证:MD5值
    1. public class TestFileMD5 {  
    2.       
    3.     public final static String[] hexDigits = { "0", "1", "2", "3", "4", "5",  
    4.         "6", "7", "8", "9", "a", "b", "c", "d", "e", "f" };  
    5.       
    6.     /** 
    7.      * 获取文件的MD5值 
    8.      * @param file 
    9.      * @return 
    10.      */  
    11.     public static String getFileMD5(File file){  
    12.         String md5 = null;  
    13.         FileInputStream fis = null;  
    14.         FileChannel fileChannel = null;  
    15.         try {  
    16.             fis = new FileInputStream(file);  
    17.             fileChannel = fis.getChannel();  
    18.             MappedByteBuffer byteBuffer = fileChannel.map(FileChannel.MapMode.READ_ONLY, 0, file.length());  
    19.               
    20.             try {  
    21.                 MessageDigest md = MessageDigest.getInstance("MD5");  
    22.                 md.update(byteBuffer);  
    23.                 md5 = byteArrayToHexString(md.digest());  
    24.             } catch (NoSuchAlgorithmException e) {  
    25.                   
    26.                 e.printStackTrace();  
    27.             }  
    28.         } catch (FileNotFoundException e) {  
    29.               
    30.             e.printStackTrace();  
    31.         } catch (IOException e) {  
    32.               
    33.             e.printStackTrace();  
    34.         }finally{  
    35.             try {  
    36.                 fileChannel.close();  
    37.                 fis.close();  
    38.             } catch (IOException e) {  
    39.                   
    40.                 e.printStackTrace();  
    41.             }  
    42.         }  
    43.           
    44.         return md5;  
    45.     }  
    46.       
    47.     /** 
    48.      * 字节数组转十六进制字符串 
    49.      * @param digest 
    50.      * @return 
    51.      */  
    52.     private static String byteArrayToHexString(byte[] digest) {  
    53.           
    54.         StringBuffer buffer = new StringBuffer();  
    55.         for(int i=0; i<digest.length; i++){  
    56.             buffer.append(byteToHexString(digest[i]));  
    57.         }  
    58.         return buffer.toString();  
    59.     }  
    60.       
    61.     /** 
    62.      * 字节转十六进制字符串 
    63.      * @param b 
    64.      * @return 
    65.      */  
    66.     private static String byteToHexString(byte b) {  
    67.         //  int d1 = n/16;   
    68.              int d1 = (b&0xf0)>>4;  
    69.                
    70.         //   int d2 = n%16;   
    71.              int d2 = b&0xf;  
    72.              return hexDigits[d1] + hexDigits[d2];  
    73.     }  
    74.       
    75.     //入口   
    76.     public static void main(String [] args) throws Exception{  
    77.         System.out.println("-----测试创建文件的md5后缀----------");  
    78.           
    79.         File file = new File("E:/jquery-1.9.1.min.js");  
    80.           
    81.         if(!file.exists()){  
    82.             file.createNewFile();  
    83.         }  
    84.         //获取参数   
    85.         String parent = file.getParent();  
    86.           
    87.         System.out.println(parent);  
    88.         String fileName = file.getName();  
    89.         System.out.println(fileName);  
    90.         //首先获取文件的MD5   
    91.         String md5 = getFileMD5(file);  
    92.           
    93.         //93d97357be249c61407fa21aa434e72f   
    94.         System.out.println("-----获取的md5:" + md5);  
    95.           
    96.         //组装   
    97.         File md5File = new File(parent + fileName +".md5");  
    98.         if(md5File.exists()){  
    99.             md5File.delete();  
    100.             md5File.createNewFile();  
    101.         }  
    102.           
    103.         FileOutputStream fos = new FileOutputStream(md5File);  
    104.         fos.write(md5.getBytes());  
    105.           
    106.         fos.flush();  
    107.         fos.close();  
    108.           
    109.         System.out.println("--------完成---------");  
    110.     }  
    111. }  

    注意:
    使用md5的方式对文件进行加密,以获取md5值,可以知道该文件的内容是否被修改过,
    因为修改过文件内容,再次对该文件进行加密的话,获取的md5值将发生变化。





    展开全文
  • 适用于一些md5验证的场合,每次处理之后都生成随机的md5验证码,响应速度快,可批量修改。处理之后不影响文件的使用。
  • MD5校验小工具.exe

    2015-08-07 10:03:39
    检测文件是否被修改过.
  • C# 获取MD5 (MD5计算,MD5小工具)

    千次阅读 2016-11-12 14:46:53
    拖拽文件或文件夹至getMD5.exe上,可自动计算文件或文件夹下所有文件的MD5值,保存至文件MD5.txt中 方式三: 通过cmd命令调用(类似方式二) REM 获取1.txt和files目录下所有文件的MD5值 getMD5.exe &...

    方式一:

    双击运行,输入字符串计算MD5值;或拖动任意文件或文件夹到到工具上,自动计算MD5值。

     

    方式二:

    拖拽文件或文件夹至getMD5.exe上,可自动计算文件或文件夹下所有文件的MD5值,保存至文件MD5.txt中

     

    方式三:

    通过cmd命令调用(类似方式二)

     

    REM 获取1.txt和files目录下所有文件的MD5值
    getMD5.exe "D:\tmp\1.txt;C:\Users\Administrator\Desktop\files"

     

     

     

    MD5计算工具下载

     

    工具源码

     
    using System;
    using System.Collections.Generic;
    using System.IO;
    using System.Linq;
    using System.Text;
    using System.Threading.Tasks;
    
    namespace getMD5
    {
        //示例: 
        // MD5.Encrypt("a");                        // 计算字符串MD5值
        // MD5.Encrypt(new FileInfo("D:\\1.rar"));  // 计算文件MD5值
        // MD5.Encrypt(byte[] Bytes);               // 计算Byte数组MD5值
    
        //MD5 ("") = d41d8cd98f00b204e9800998ecf8427e   
        //MD5 ("a") = 0cc175b9c0f1b6a831c399e269772661   
        //MD5 ("abc") = 900150983cd24fb0d6963f7d28e17f72   
        //MD5 ("message digest") = f96b697d7cb7938d525a2f31aaf161d0   
        //MD5 ("abcdefghijklmnopqrstuvwxyz") = c3fcd3d76192e4007dfb496cca67e13b  
        class MD5
        {
    
            #region MD5调用接口
    
            /// <summary>
            /// 计算data的MD5值
            /// </summary>
            public static string Encrypt(string data)
            {
                uint[] X = To16Array(data);
                return calculate(X);
            }
    
            /// <summary>
            /// 计算byte数组的MD5值
            /// </summary>
            public static string Encrypt(byte[] Bytes)
            {
                uint[] X = To16Array(Bytes);
                return calculate(X);
            }
    
            /// <summary>
            /// 计算文件的MD5值
            /// </summary>
            public static string Encrypt(FileInfo file)
            {
                uint[] X = To16Array(file);
                return calculate(X);
            }
    
            #endregion
    
    
            #region MD5计算逻辑
    
            /// <summary>
            /// 转化byte数组为uint数组,数组长度为16的倍数
            /// 
            /// 1、字符串转化为字节数组,每4个字节转化为一个uint,依次存储到uint数组
            /// 2、附加0x80作为最后一个字节
            /// 3、在uint数组最后位置记录文件字节长度信息
            /// </summary>
            public static uint[] To16Array(byte[] Bytes)
            {
                uint DataLen = (uint)Bytes.Length;
    
                // 计算FileLen对应的uint长度(要求为16的倍数、预留2个uint、最小为16)
                uint ArrayLen = (((DataLen + 8) / 64) + 1) * 16;     
                uint[] Array = new uint[ArrayLen];
    
                uint ArrayPos = 0;
                int pos = 0;
                uint ByteCount = 0;
                for (ByteCount = 0; ByteCount < DataLen; ByteCount++)
                {
                    // 每4个Byte转化为1个uint
                    ArrayPos = ByteCount / 4;
                    pos = (int)(ByteCount % 4) * 8;
                    Array[ArrayPos] = Array[ArrayPos] | ((uint)Bytes[ByteCount] << pos);
                }
    
                // 附加0x80作为最后一个字节,添加到uint数组对应位置
                ArrayPos = ByteCount / 4;
                pos = (int)(ByteCount % 4) * 8;
                Array[ArrayPos] = Array[ArrayPos] | ((uint)0x80 << pos);
    
                // 记录总长度信息
                Array[ArrayLen - 2] = (DataLen << 3);
                Array[ArrayLen - 1] = (DataLen >> 29);
    
                return Array;
            }
    
            /// <summary>
            /// 转化字符串为uint数组,数组长度为16的倍数
            /// 
            /// 1、字符串转化为字节数组,每4个字节转化为一个uint,依次存储到uint数组
            /// 2、附加0x80作为最后一个字节
            /// 3、在uint数组最后位置记录文件字节长度信息
            /// </summary>
            public static uint[] To16Array(string data)
            {
                byte[] datas = System.Text.Encoding.Default.GetBytes(data);
                return To16Array(datas);
            }
    
            /// <summary>
            /// 转化文件为uint数组,数组长度为16的倍数
            /// 
            /// 1、读取文件字节信息,每4个字节转化为一个uint,依次存储到uint数组
            /// 2、附加0x80作为最后一个字节
            /// 3、在uint数组最后位置记录文件字节长度信息
            /// </summary>
            public static uint[] To16Array(FileInfo info)
            {
                FileStream fs = new FileStream(info.FullName, FileMode.Open);// 读取方式打开,得到流
                int SIZE = 1024 * 1024 * 10;        // 10M缓存
                byte[] datas = new byte[SIZE];      // 要读取的内容会放到这个数组里
                int countI = 0;
                long offset = 0;
    
                // 计算FileLen对应的uint长度(要求为16的倍数、预留2个uint、最小为16)
                uint FileLen = (uint)info.Length;
                uint ArrayLen = (((FileLen + 8) / 64) + 1) * 16;     
                uint[] Array = new uint[ArrayLen];
    
                int pos = 0;
                uint ByteCount = 0;
                uint ArrayPos = 0;
                while (ByteCount < FileLen)
                {
                    if (countI == 0)
                    {
                        fs.Seek(offset, SeekOrigin.Begin);// 定位到指定字节
                        fs.Read(datas, 0, datas.Length);
    
                        offset += SIZE;
                    }
    
                    // 每4个Byte转化为1个uint
                    ArrayPos = ByteCount / 4;
                    pos = (int)(ByteCount % 4) * 8;
                    Array[ArrayPos] = Array[ArrayPos] | ((uint)datas[countI] << pos);
    
                    ByteCount = ByteCount + 1;
    
                    countI++;
                    if (countI == SIZE) countI = 0;
                }
    
                // 附加0x80作为最后一个字节,添加到uint数组对应位置
                ArrayPos = ByteCount / 4;
                pos = (int)(ByteCount % 4) * 8;
                Array[ArrayPos] = Array[ArrayPos] | ((uint)0x80 << pos);
    
                // 记录总长度信息
                Array[ArrayLen - 2] = (FileLen<< 3);
                Array[ArrayLen - 1] = (FileLen>>29);
    
                fs.Close();
                return Array;
            }
    
    
    
            private static uint F(uint x, uint y, uint z)
            {
                return (x & y) | ((~x) & z);
            }
            private static uint G(uint x, uint y, uint z)
            {
                return (x & z) | (y & (~z));
            }
    
            // 0^0^0 = 0
            // 0^0^1 = 1
            // 0^1^0 = 1
            // 0^1^1 = 0
            // 1^0^0 = 1
            // 1^0^1 = 0
            // 1^1^0 = 0
            // 1^1^1 = 1
            private static uint H(uint x, uint y, uint z)
            {
                return (x ^ y ^ z);
            }
            private static uint I(uint x, uint y, uint z)
            {
                return (y ^ (x | (~z)));
            }
    
            // 循环左移
            private static uint RL(uint x, int y)
            {
                y = y % 32;
                return (x << y) | (x >> (32 - y));
            }
    
            private static void md5_FF(ref uint a, uint b, uint c, uint d, uint x, int s, uint ac)
            {
                uint f = F(b, c, d);
                a = x + ac + a + f;
    
                a = RL(a, s);
                a = a + b;
            }
            private static void md5_GG(ref uint a, uint b, uint c, uint d, uint x, int s, uint ac)
            {
                uint g = G(b, c, d);
                a = x + ac + a + g;
    
                a = RL(a, s);
                a = a + b;
            }
            private static void md5_HH(ref uint a, uint b, uint c, uint d, uint x, int s, uint ac)
            {
                uint h = H(b, c, d);
                a = x + ac + a + h;
    
                a = RL(a, s);
                a = a + b;
            }
            private static void md5_II(ref uint a, uint b, uint c, uint d, uint x, int s, uint ac)
            {
                uint i = I(b, c, d);
                a = x + ac + a + i;
    
                a = RL(a, s);
                a = a + b;
            }
    
            private static string RHex(uint n)
            {
                string S = Convert.ToString(n, 16);
                return ReOrder(S);
            }
    
            // 16进制串重排序 67452301 -> 01234567
            private static string ReOrder(String S)
            {
                string T = "";
                for (int i = S.Length - 2; i >= -1; i = i - 2)
                {
                    if (i == -1) T = T + "0" + S[i + 1];
                    else T = T + "" + S[i] + S[i + 1];
                }
                return T;
            }
    
    
            /// <summary>
            /// 对长度为16倍数的uint数组,执行md5数据摘要,输出md5信息
            /// </summary>
            public static string calculate(uint[] x)
            {
                //uint time1 = DateTime.Now.Ticks;
    
                // 7   12  17   22
                // 5   9   14   20
                // 4   11  16   23
                // 6   10  15   21
                const int S11 = 7;
                const int S12 = 12;
                const int S13 = 17;
                const int S14 = 22;
                const int S21 = 5;
                const int S22 = 9;
                const int S23 = 14;
                const int S24 = 20;
                const int S31 = 4;
                const int S32 = 11;
                const int S33 = 16;
                const int S34 = 23;
                const int S41 = 6;
                const int S42 = 10;
                const int S43 = 15;
                const int S44 = 21;
    
                uint a = 0x67452301;
                uint b = 0xEFCDAB89;
                uint c = 0x98BADCFE;
                uint d = 0x10325476;
    
                for (int k = 0; k < x.Length; k += 16)
                {
                    uint AA = a;
                    uint BB = b;
                    uint CC = c;
                    uint DD = d;
    
                    md5_FF(ref a, b, c, d, x[k + 0], S11, 0xD76AA478);  // 3604027302
                    md5_FF(ref d, a, b, c, x[k + 1], S12, 0xE8C7B756);  // 877880356
                    md5_FF(ref c, d, a, b, x[k + 2], S13, 0x242070DB);  // 2562383102
                    md5_FF(ref b, c, d, a, x[k + 3], S14, 0xC1BDCEEE);
                    md5_FF(ref a, b, c, d, x[k + 4], S11, 0xF57C0FAF);
                    md5_FF(ref d, a, b, c, x[k + 5], S12, 0x4787C62A);
                    md5_FF(ref c, d, a, b, x[k + 6], S13, 0xA8304613);
                    md5_FF(ref b, c, d, a, x[k + 7], S14, 0xFD469501);
                    md5_FF(ref a, b, c, d, x[k + 8], S11, 0x698098D8);
                    md5_FF(ref d, a, b, c, x[k + 9], S12, 0x8B44F7AF);
                    md5_FF(ref c, d, a, b, x[k + 10], S13, 0xFFFF5BB1);
                    md5_FF(ref b, c, d, a, x[k + 11], S14, 0x895CD7BE);
                    md5_FF(ref a, b, c, d, x[k + 12], S11, 0x6B901122);
                    md5_FF(ref d, a, b, c, x[k + 13], S12, 0xFD987193);
                    md5_FF(ref c, d, a, b, x[k + 14], S13, 0xA679438E);
                    md5_FF(ref b, c, d, a, x[k + 15], S14, 0x49B40821); //3526238649
                    md5_GG(ref a, b, c, d, x[k + 1], S21, 0xF61E2562);
                    md5_GG(ref d, a, b, c, x[k + 6], S22, 0xC040B340);  //1572812400
                    md5_GG(ref c, d, a, b, x[k + 11], S23, 0x265E5A51);
                    md5_GG(ref b, c, d, a, x[k + 0], S24, 0xE9B6C7AA);
                    md5_GG(ref a, b, c, d, x[k + 5], S21, 0xD62F105D);
                    md5_GG(ref d, a, b, c, x[k + 10], S22, 0x2441453);
                    md5_GG(ref c, d, a, b, x[k + 15], S23, 0xD8A1E681);
                    md5_GG(ref b, c, d, a, x[k + 4], S24, 0xE7D3FBC8);
                    md5_GG(ref a, b, c, d, x[k + 9], S21, 0x21E1CDE6);
                    md5_GG(ref d, a, b, c, x[k + 14], S22, 0xC33707D6);
                    md5_GG(ref c, d, a, b, x[k + 3], S23, 0xF4D50D87);
                    md5_GG(ref b, c, d, a, x[k + 8], S24, 0x455A14ED);
                    md5_GG(ref a, b, c, d, x[k + 13], S21, 0xA9E3E905);
                    md5_GG(ref d, a, b, c, x[k + 2], S22, 0xFCEFA3F8);
                    md5_GG(ref c, d, a, b, x[k + 7], S23, 0x676F02D9);
                    md5_GG(ref b, c, d, a, x[k + 12], S24, 0x8D2A4C8A);
                    md5_HH(ref a, b, c, d, x[k + 5], S31, 0xFFFA3942);  // 3750198684 2314002400 1089690627 990001115 0 4 -> 2749600077
                    md5_HH(ref d, a, b, c, x[k + 8], S32, 0x8771F681);  // 990001115
                    md5_HH(ref c, d, a, b, x[k + 11], S33, 0x6D9D6122); // 1089690627
                    md5_HH(ref b, c, d, a, x[k + 14], S34, 0xFDE5380C); // 2314002400
                    md5_HH(ref a, b, c, d, x[k + 1], S31, 0xA4BEEA44);  // 555633090
                    md5_HH(ref d, a, b, c, x[k + 4], S32, 0x4BDECFA9);
                    md5_HH(ref c, d, a, b, x[k + 7], S33, 0xF6BB4B60);
                    md5_HH(ref b, c, d, a, x[k + 10], S34, 0xBEBFBC70);
                    md5_HH(ref a, b, c, d, x[k + 13], S31, 0x289B7EC6);
                    md5_HH(ref d, a, b, c, x[k + 0], S32, 0xEAA127FA);
                    md5_HH(ref c, d, a, b, x[k + 3], S33, 0xD4EF3085);
                    md5_HH(ref b, c, d, a, x[k + 6], S34, 0x4881D05);
                    md5_HH(ref a, b, c, d, x[k + 9], S31, 0xD9D4D039);
                    md5_HH(ref d, a, b, c, x[k + 12], S32, 0xE6DB99E5);
                    md5_HH(ref c, d, a, b, x[k + 15], S33, 0x1FA27CF8);
                    md5_HH(ref b, c, d, a, x[k + 2], S34, 0xC4AC5665);  // 1444303940
                    md5_II(ref a, b, c, d, x[k + 0], S41, 0xF4292244);  // 808311156
                    md5_II(ref d, a, b, c, x[k + 7], S42, 0x432AFF97);
                    md5_II(ref c, d, a, b, x[k + 14], S43, 0xAB9423A7);
                    md5_II(ref b, c, d, a, x[k + 5], S44, 0xFC93A039);
                    md5_II(ref a, b, c, d, x[k + 12], S41, 0x655B59C3);
                    md5_II(ref d, a, b, c, x[k + 3], S42, 0x8F0CCC92);
                    md5_II(ref c, d, a, b, x[k + 10], S43, 0xFFEFF47D);
                    md5_II(ref b, c, d, a, x[k + 1], S44, 0x85845DD1);
                    md5_II(ref a, b, c, d, x[k + 8], S41, 0x6FA87E4F);
                    md5_II(ref d, a, b, c, x[k + 15], S42, 0xFE2CE6E0);
                    md5_II(ref c, d, a, b, x[k + 6], S43, 0xA3014314);
                    md5_II(ref b, c, d, a, x[k + 13], S44, 0x4E0811A1);
                    md5_II(ref a, b, c, d, x[k + 4], S41, 0xF7537E82);
                    md5_II(ref d, a, b, c, x[k + 11], S42, 0xBD3AF235);
                    md5_II(ref c, d, a, b, x[k + 2], S43, 0x2AD7D2BB);
                    md5_II(ref b, c, d, a, x[k + 9], S44, 0xEB86D391);  // 4120542881
    
                    a = a + AA; //3844921825
                    b = b + BB;
                    c = c + CC;
                    d = d + DD;
                }
    
                string MD5 = RHex(a) + RHex(b) + RHex(c) + RHex(d);
    
                //uint time2 = DateTime.Now.Ticks;
                //MessageBox.Show("MD5计算耗时:" + ((time2 - time1) / 10000000f) + "秒");
    
                return MD5;
            }
    
            #endregion
    
        }
    }
    

     

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Threading.Tasks;
    using System.Windows.Forms;
    
    namespace getMD5
    {
        static class Program
        {
            /// <summary>
            /// 应用程序的主入口点。
            /// </summary>
            [STAThread]
            static void Main(string[] args)
            {
                Application.EnableVisualStyles();
                Application.SetCompatibleTextRenderingDefault(false);
    
                if (args.Length == 0) Application.Run(new Form_MD5());
                else if (args.Length == 1)
                {
                    string[] files = args[0].Split(';');
                    string filesNames = Form_MD5.toSubDirFileNames(files);
                    files = filesNames.Split(';');
    
                    string tmp = Form_MD5.getFilesMD5(files);   // 计算文件MD5值
                    Form_MD5.SaveProcess(tmp);
                }
            }
        }
    }
    
    using System;
    using System.Collections.Generic;
    using System.ComponentModel;
    using System.Data;
    using System.Drawing;
    using System.Linq;
    using System.Text;
    using System.Threading.Tasks;
    using System.Windows.Forms;
    
    namespace getMD5
    {
        public partial class Form_MD5 : Form
        {
            public Form_MD5()
            {
                InitializeComponent();
            }
    
            private void button1_Click(object sender, EventArgs e)
            {
                textBox1.Text = MD5.Encrypt(textBox1.Text, 32);
            }
    
            private void Form_DragEnter(object sender, DragEventArgs e)
            {
                dragEnter(e);
            }
    
            private void Form_DragDrop(object sender, DragEventArgs e)
            {
                TextBox textBox = sender as TextBox;
                textBox.Text = dragDrop(e);                 // 获取拖入的文件
                string[] files = textBox.Text.Split(';');
    
                string tmp = getFilesMD5(files);            // 计算文件MD5值
                textBox1.Text = tmp;
                SaveProcess(tmp, "MD5.txt");
            }
    
    
            // 计算各文件对应的MD5值
            public static String getFilesMD5(string[] files)
            {
                string tmp = "";
    
                foreach (string file in files)
                {
                    if (System.IO.File.Exists(file))
                    {
                        string data = fileToString(file);
                        string md5 = MD5.Encrypt(data, 32);
                        tmp += "\r\n" + file + "(" + md5 + ")";
                    }
                }
    
                return tmp;
            }
    
            #region 文件读取与保存
    
            /// <summary>  
            /// 获取文件中的数据串  
            /// </summary>  
            public static string fileToString(String filePath)
            {
                string str = "";
    
                //获取文件内容  
                if (System.IO.File.Exists(filePath))
                {
                    System.IO.StreamReader file1 = new System.IO.StreamReader(filePath, Encoding.Default);//读取文件中的数据  
                    str = file1.ReadToEnd();                                            //读取文件中的全部数据  
    
                    file1.Close();
                    file1.Dispose();
                }
                return str;
            }
    
            /// <summary>
            /// 保存数据data到文件处理过程,返回值为保存的文件名
            /// </summary>  
            public static String SaveProcess(String data, String name = "", String CurDir = "")
            {
                if (CurDir.Equals("")) CurDir = System.AppDomain.CurrentDomain.BaseDirectory;           //设置当前目录  
                if (name.Equals("")) name = "MD5.txt";
                if (!System.IO.Directory.Exists(CurDir)) System.IO.Directory.CreateDirectory(CurDir);   //该路径不存在时,在当前文件目录下创建文件夹"导出.."  
    
                //不存在该文件时先创建  
                String filePath = CurDir + name;
                System.IO.StreamWriter file1 = new System.IO.StreamWriter(filePath, false);     //文件已覆盖方式添加内容  
    
                file1.Write(data);                                                              //保存数据到文件  
    
                file1.Close();                                                                  //关闭文件  
                file1.Dispose();                                                                //释放对象  
    
                return filePath;
            }
    
            #endregion
    
    
            # region 文件拖拽
    
            /// <summary>  
            /// 文件拖进事件处理:  
            /// </summary>  
            public void dragEnter(DragEventArgs e)
            {
                if (e.Data.GetDataPresent(DataFormats.FileDrop))    //判断拖来的是否是文件  
                    e.Effect = DragDropEffects.Link;                //是则将拖动源中的数据连接到控件  
                else e.Effect = DragDropEffects.None;
            }
    
            /// <summary>  
            /// 文件放下事件处理:  
            /// 放下, 另外需设置对应控件的 AllowDrop = true;   
            /// 获取的文件名形如 "d:\1.txt;d:\2.txt"  
            /// </summary>  
            public string dragDrop(DragEventArgs e)
            {
                Array file = (System.Array)e.Data.GetData(DataFormats.FileDrop);//将拖来的数据转化为数组存储
                return toSubDirFileNames(file);
            }
    
            // 获取所有files目录下的所有文件,转化为单个串
            public static string toSubDirFileNames(Array files)
            {
                StringBuilder filesName = new StringBuilder("");
    
                foreach (object I in files)
                {
                    string str = I.ToString();
    
                    System.IO.FileInfo info = new System.IO.FileInfo(str);
                    //若为目录,则获取目录下所有子文件名  
                    if ((info.Attributes & System.IO.FileAttributes.Directory) != 0)
                    {
                        str = getAllFiles(str);
                        if (!str.Equals("")) filesName.Append((filesName.Length == 0 ? "" : ";") + str);
                    }
                    //若为文件,则获取文件名  
                    else if (System.IO.File.Exists(str))
                        filesName.Append((filesName.Length == 0 ? "" : ";") + str);
                }
    
                return filesName.ToString();
            }
    
            /// <summary>  
            /// 判断path是否为目录  
            /// </summary>  
            public bool IsDirectory(String path)
            {
                System.IO.FileInfo info = new System.IO.FileInfo(path);
                return (info.Attributes & System.IO.FileAttributes.Directory) != 0;
            }
    
            /// <summary>  
            /// 获取目录path下所有子文件名  
            /// </summary>  
            public static string getAllFiles(String path)
            {
                StringBuilder str = new StringBuilder("");
                if (System.IO.Directory.Exists(path))
                {
                    //所有子文件名  
                    string[] files = System.IO.Directory.GetFiles(path);
                    foreach (string file in files)
                        str.Append((str.Length == 0 ? "" : ";") + file);
    
                    //所有子目录名  
                    string[] Dirs = System.IO.Directory.GetDirectories(path);
                    foreach (string dir in Dirs)
                    {
                        string tmp = getAllFiles(dir);  //子目录下所有子文件名  
                        if (!tmp.Equals("")) str.Append((str.Length == 0 ? "" : ";") + tmp);
                    }
                }
                return str.ToString();
            }
    
            # endregion
    
        }
    }
    
    namespace getMD5
    {
        partial class Form_MD5
        {
            /// <summary>
            /// 必需的设计器变量。
            /// </summary>
            private System.ComponentModel.IContainer components = null;
    
            /// <summary>
            /// 清理所有正在使用的资源。
            /// </summary>
            /// <param name="disposing">如果应释放托管资源,为 true;否则为 false。</param>
            protected override void Dispose(bool disposing)
            {
                if (disposing && (components != null))
                {
                    components.Dispose();
                }
                base.Dispose(disposing);
            }
    
            #region Windows 窗体设计器生成的代码
    
            /// <summary>
            /// 设计器支持所需的方法 - 不要
            /// 使用代码编辑器修改此方法的内容。
            /// </summary>
            private void InitializeComponent()
            {
                this.components = new System.ComponentModel.Container();
                this.button1 = new System.Windows.Forms.Button();
                this.textBox1 = new System.Windows.Forms.TextBox();
                this.toolTip1 = new System.Windows.Forms.ToolTip(this.components);
                this.SuspendLayout();
                // 
                // button1
                // 
                this.button1.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Right)));
                this.button1.Location = new System.Drawing.Point(182, 308);
                this.button1.Name = "button1";
                this.button1.Size = new System.Drawing.Size(75, 23);
                this.button1.TabIndex = 0;
                this.button1.Text = "计算MD5";
                this.button1.UseVisualStyleBackColor = true;
                this.button1.Click += new System.EventHandler(this.button1_Click);
                // 
                // textBox1
                // 
                this.textBox1.AllowDrop = true;
                this.textBox1.Anchor = ((System.Windows.Forms.AnchorStyles)((((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom) 
                | System.Windows.Forms.AnchorStyles.Left) 
                | System.Windows.Forms.AnchorStyles.Right)));
                this.textBox1.Location = new System.Drawing.Point(0, 0);
                this.textBox1.Margin = new System.Windows.Forms.Padding(0);
                this.textBox1.Multiline = true;
                this.textBox1.Name = "textBox1";
                this.textBox1.ScrollBars = System.Windows.Forms.ScrollBars.Both;
                this.textBox1.Size = new System.Drawing.Size(257, 305);
                this.textBox1.TabIndex = 1;
                this.toolTip1.SetToolTip(this.textBox1, "可拖动文件至此,查看文件的MD5值");
                this.textBox1.DragDrop += new System.Windows.Forms.DragEventHandler(this.Form_DragDrop);
                this.textBox1.DragEnter += new System.Windows.Forms.DragEventHandler(this.Form_DragEnter);
                // 
                // Form1
                // 
                this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 12F);
                this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font;
                this.ClientSize = new System.Drawing.Size(257, 335);
                this.Controls.Add(this.textBox1);
                this.Controls.Add(this.button1);
                this.Name = "Form1";
                this.Text = "MD5";
                this.ResumeLayout(false);
                this.PerformLayout();
    
            }
    
            #endregion
    
            private System.Windows.Forms.Button button1;
            private System.Windows.Forms.TextBox textBox1;
            private System.Windows.Forms.ToolTip toolTip1;
        }
    }

     

     

    工具源码下载

    开源地址

     

    展开全文
  • 此工具主要是验证我们下载的软件是否是未经第三方修改的原生软件,通过MD5码可以判断软件是否被修改,本软件(MD5验证工具.exe)文件的MD5为:723dc31579a08ab69f06ff4349b730ee 本工具大家可以免费传播与使用,如...
  • md5加密原理 MD5简介

    千次阅读 2018-11-10 09:54:28
    md5加密原理 MD5简介

    分享一下我老师大神的人工智能教程!零基础,通俗易懂!http://blog.csdn.net/jiangjunshow

    也欢迎大家转载本篇文章。分享知识,造福人民,实现我们中华民族伟大复兴!

                     

    MD5简介


    MD5的全称是Message-Digest Algorithm 5,在90年代初由MIT的计算机科学实验室和RSA Data Security Inc发明,经MD2、MD3和MD4发展而来。

    Message-Digest泛指字节串(Message)的Hash变换,就是把一个任意长度的字节串变换成一定长的大整数。请注意我使用了“字节串”而不是“字符串”这个词,是因为这种变换只与字节的值有关,与字符集或编码方式无关。

    MD5将任意长度的“字节串”变换成一个128bit的大整数,并且它是一个不可逆的字符串变换算法,换句话说就是,即使你看到源程序和算法描述,也无法将一个MD5的值变换回原始的字符串,从数学原理上说,是因为原始的字符串有无穷多个,这有点象不存在反函数的数学函数。

    MD5的典型应用是对一段Message(字节串)产生fingerprint(指纹),以防止被“篡改”。举个例子,你将一段话写在一个叫readme.txt文件中,并对这个readme.txt产生一个MD5的值并记录在案,然后你可以传播这个文件给别人,别人如果修改了文件中的任何内容,你对这个文件重新计算MD5时就会发现。如果再有一个第三方的认证机构,用MD5还可以防止文件作者的“抵赖”,这就是所谓的数字签名应用。

    MD5还广泛用于加密和解密技术上,在很多操作系统中,用户的密码是以MD5值(或类似的其它算法)的方式保存的,用户Login的时候,系统是把用户输入的密码计算成MD5值,然后再去和系统中保存的MD5值进行比较,而系统并不“知道”用户的密码是什么。

    一些黑客破获这种密码的方法是一种被称为“跑字典”的方法。有两种方法得到字典,一种是日常搜集的用做密码的字符串表,另一种是用排列组合方法生成的,先用MD5程序计算出这些字典项的MD5值,然后再用目标的MD5值在这个字典中检索。

    即使假设密码的最大长度为8,同时密码只能是字母和数字,共26+26+10=62个字符,排列组合出的字典的项数则是P(62,1)+P(62,2)….+P(62,8),那也已经是一个很天文的数字了,存储这个字典就需要TB级的磁盘组,而且这种方法还有一个前提,就是能获得目标账户的密码MD5值的情况下才可以。

    在很多电子商务和社区应用中,管理用户的Account是一种最常用的基本功能,尽管很多ApplicationServer提供了这些基本组件,但很多应用开发者为了管理的更大的灵活性还是喜欢采用关系数据库来管理用户,懒惰的做法是用户的密码往往使用明文或简单的变换后直接保存在数据库中,因此这些用户的密码对软件开发者或系统管理员来说可以说毫无保密可言,本文的目的是介绍MD5的JavaBean的实现,同时给出用MD5来处理用户的Account密码的例子,这种方法使得管理员和程序设计者都无法看到用户的密码,尽管他们可以初始化它们。但重要的一点是对于用户密码设置习惯的保护。

    有兴趣的读者可以从这里取得MD5也就是RFC 1321的文本。http://www.ietf.org/rfc/rfc1321.txt 

    实现策略


    MD5的算法在RFC1321中实际上已经提供了C的实现,我们其实马上就能想到,至少有两种用Java实现它的方法,第一种是,用Java语言重新写整个算法,或者再说简单点就是把C程序改写成Java程序。第二种是,用JNI(Java NativeInterface)来实现,核心算法仍然用这个C程序,用Java类给它包个壳。

    但我个人认为,JNI应该是Java为了解决某类问题时的没有办法的办法(比如与操作系统或I/O设备密切相关的应用),同时为了提供和其它语言的互操作性的一个手段。使用JNI带来的最大问题是引入了平台的依赖性,打破了SUN所鼓吹的“一次编写到处运行”的Java好处。因此,我决定采取第一种方法,一来和大家一起尝试一下“一次编写到处运行”的好处,二来检验一下Java 2现在对于比较密集的计算的效率问题。

    实现过程


    限于这篇文章的篇幅,同时也为了更多的读者能够真正专注于问题本身,我不想就某一种Java集成开发环境来介绍这个JavaBean的制作过程,介绍一个方法时我发现步骤和命令很清晰,我相信有任何一种Java集成环境三天以上经验的读者都会知道如何把这些代码在集成环境中编译和运行。用集成环境讲述问题往往需要配很多屏幕截图,这也是我一直对集成环境很头疼的原因。我使用了一个普通的文本编辑器,同时使用了Sun公司标准的JDK 1.3.0 for Windows NT。

    其实把C转换成Java对于一个有一定C语言基础的程序员并不困难,这两个语言的基本语法几乎完全一致.我大概花了一个小时的时间完成了代码的转换工作,我主要作了下面几件事:

    把必须使用的一些#define的宏定义变成Class中的final static,这样保证在一个进程空间中的多个Instance共享这些数据
    删去了一些无用的#if define,因为我只关心MD5,这个推荐的C实现同时实现了MD2 MD3和 MD4,而且有些#if define还和C不同编译器有关
    将一些计算宏转换成final static 成员函数。
    所有的变量命名与原来C实现中保持一致,在大小写上作一些符合Java习惯的变化,计算过程中的C函数变成了private方法(成员函数)。
    关键变量的位长调整
    定义了类和方法
    需要注意的是,很多早期的C编译器的int类型是16 bit的,MD5使用了unsigned longint,并认为它是32bit的无符号整数。而在Java中int是32 bit的,long是64bit的。在MD5的C实现中,使用了大量的位操作。这里需要指出的一点是,尽管Java提供了位操作,由于Java没有unsigned类型,对于右移位操作多提供了一个无符号右移:>>>,等价于C中的 >> 对于unsigned 数的处理。

    因为Java不提供无符号数的运算,两个大int数相加就会溢出得到一个负数或异常,因此我将一些关键变量在Java中改成了long类型(64bit)。我个人认为这比自己去重新定义一组无符号数的类同时重载那些运算符要方便,同时效率高很多并且代码也易读,OO(ObjectOriented)的滥用反而会导致效率低下。

    限于篇幅,这里不再给出原始的C代码,有兴趣对照的读者朋友可以去看RFC 1321。MD5.java源代码

    测试


    在RFC 1321中,给出了Test suite用来检验你的实现是否正确:

    MD5 ("") = d41d8cd98f00b204e9800998ecf8427e

    MD5 ("a") = 0cc175b9c0f1b6a831c399e269772661

    MD5 ("abc") = 900150983cd24fb0d6963f7d28e17f72

    MD5 ("message digest") = f96b697d7cb7938d525a2f31aaf161d0

    MD5 ("abcdefghijklmnopqrstuvwxyz") = c3fcd3d76192e4007dfb496cca67e13b

    ……

    这些输出结果的含义是指:空字符串””的MD5值是d41d8cd98f00b204e9800998ecf8427e,字符串”a”的MD5值是0cc175b9c0f1b6a831c399e269772661……
    编译并运行我们的程序:
    javac –d . MD5.java
    java beartool.MD5
    为了将来不与别人的同名程序冲突,我在我的程序的第一行使用了package beartool;

    因此编译命令javac –d . MD5.java 命令在我们的工作目录下自动建立了一个beartool目录,目录下放着编译成功的 MD5.class

    我们将得到和Test suite同样的结果。当然还可以继续测试你感兴趣的其它MD5变换,例如:

    java beartool.MD5 1234

    将给出1234的MD5值。

    可能是我的计算机知识是从Apple II和Z80单板机开始的,我对大写十六进制代码有偏好,如果您想使用小写的Digest String只需要把byteHEX函数中的A、B、C、D、E、F改成a、b、 c、d、e、f就可以了。

    MD5据称是一种比较耗时的计算,我们的Java版MD5一闪就算出来了,没遇到什么障碍,而且用肉眼感觉不出来Java版的MD5比C版的慢。

    为了测试它的兼容性,我把这个MD5.class文件拷贝到我的另一台Linux+IBM JDK 1.3的机器上,执行后得到同样结果,确实是“一次编写到处运行了”。

    Java Bean简述


    现在,我们已经完成并简单测试了这个Java Class,我们文章的标题是做一个Java Bean。

    其实普通的Java Bean很简单,并不是什么全新的或伟大的概念,就是一个Java的Class,尽管Sun规定了一些需要实现的方法,但并不是强制的。而EJB(Enterprise JavaBean)无非规定了一些必须实现(非常类似于响应事件)的方法,这些方法是供EJB Container使用(调用)的。

    在一个JavaApplication或Applet里使用这个bean非常简单,最简单的方法是你要使用这个类的源码工作目录下建一个beartool目录,把这个class文件拷贝进去,然后在你的程序中importbeartool.MD5就可以了。最后打包成.jar或.war是保持这个相对的目录关系就行了。

    Java还有一个小小的好处是你并不需要摘除我们的MD5类中那个main方法,它已经是一个可以工作的JavaBean了。Java有一个非常大的优点是她允许很方便地让多种运行形式在同一组代码中共存,比如,你可以写一个类,它即是一个控制台Application和GUI Application,同时又是一个Applet,同时还是一个JavaBean,这对于测试、维护和发布程序提供了极大的方便,这里的测试方法main还可以放到一个内部类中,有兴趣的读者可以参考:http://help.liangjing.org/Tools/MD5.aspx 这里讲述了把测试和示例代码放在一个内部静态类的好处,是一种不错的工程化技巧和途径。

    把Java Bean装到JSP里


    正如我们在本文开头讲述的那样,我们对这个MD5Bean的应用是基于一个用户管理,这里我们假设了一个虚拟社区的用户login过程,用户的信息保存在数据库的个名为users的表中。这个表有两个字段和我们的这个例子有关,userid :char(20)和pwdmd5 :char(32),userid是这个表的PrimaryKey,pwdmd5保存密码的MD5串,MD5值是一个128bit的大整数,表示成16进制的ASCII需要32个字符。

    这里给出两个文件,login.html是用来接受用户输入的form,login.jsp用来模拟使用MD5 Bean的login过程。

    为了使我们的测试环境简单起见,我们在JSP中使用了JDK内置的JDBC-ODBC Bridge Driver,community是ODBC的DSN的名字,如果你使用其它的JDBC Driver,替换掉login.jsp中的
    Connection con= DriverManager.getConnection("jdbc:odbc:community", "", "");
    即可。

    login.jsp的工作原理很简单,通过post接收用户输入的UserID和Password,然后将Password变换成MD5串,然后在users表中寻找UserID和pwdmd5,因为UserID是users表的PrimaryKey,如果变换后的pwdmd5与表中的记录不符,那么SQL查询会得到一个空的结果集。

    这里需要简单介绍的是,使用这个Bean只需要在你的JSP应用程序的WEB-INF/classes下建立一个beartool目录,然后将MD5.class拷贝到那个目录下就可以了。如果你使用一些集成开发环境,请参考它们的deploy工具的说明。在JSP使用一个javaBean关键的一句声明是程序中的第2行:

    <jsp:useBean id='oMD5' scope='request' class='beartool.MD5'/>
    这是所有JSP规范要求JSP容器开发者必须提供的标准Tag。

    id=实际上是指示JSPContainer创建Bean的实例时用的实例变量名。在后面的<%和%>之间的Java程序中,你可以引用它。在程序中可以看到,通过pwdmd5=oMD5.getMD5ofStr (password)引用了我们的MD5 Java Bean提供的唯一一个公共方法:getMD5ofStr。

    Java ApplicationServer执行.JSP的过程是先把它预编译成.java(那些Tag在预编译时会成为java语句),然后再编译成.class。这些都是系统自动完成和维护的,那个.class也称为Servlet。当然,如果你愿意,你也可以帮助Java ApplicationServer去干本该它干的事情,自己直接去写Servlet,但用Servlet去输出HTML那简直是回到了用C写CGI程序的恶梦时代。

    如果你的输出是一个复杂的表格,比较方便的方法我想还是用一个你所熟悉的HTML编辑器编写一个“模板”,然后在把JSP代码“嵌入”进去。尽管这种JSP代码被有些专家指责为“空心粉”,它的确有个缺点是代码比较难管理和重复使用,但是程序设计永远需要的就是这样的权衡。我个人认为,对于中、小型项目,比较理想的结构是把数据表示(或不严格地称作WEB界面相关)的部分用JSP写,和界面不相关的放在Bean里面,一般情况下是不需要直接写Servlet的。

    如果你觉得这种方法不是非常的OO(Object Oriented),你可以继承(extends)它一把,再写一个bean把用户管理的功能包进去。

    到底能不能兼容?


    我测试了三种Java应用服务器环境,Resin 1.2.3、Sun J2EE 1.2、IBM WebSphere 3.5,所幸的是这个JavaBean都没有任何问题,原因其实是因为它仅仅是个计算程序,不涉及操作系统,I/O设备。其实用其它语言也能简单地实现它的兼容性的,Java的唯一优点是,你只需提供一个形态的运行码就可以了。请注意“形态”二字,现在很多计算结构和操作系统除了语言本身之外都定义了大量的代码形态,很简单的一段C语言核心代码,转换成不同形态要考虑很多问题,使用很多工具,同时受很多限制,有时候学习一种新的“形态”所花费的精力可能比解决问题本身还多。比如光Windows就有EXE、Service、的普通DLL、COMDLL以前还有OCX等等等等,在Unix上虽说要简单一些,但要也要提供一个.h定义一大堆宏,还要考虑不同平台编译器版本的位长度问题。我想这是Java对我来说的一个非常重要的魅力吧。


    MD5算法说明

    一、补位
    二、补数据长度
    三、初始化MD5参数
    四、处理位操作函数
    五、主要变换过程
    六、输出结果


    补位:
    MD5算法先对输入的数据进行补位,使得数据位长度LEN对512求余的结果是448。即数据扩展至K*512+448位。即K*64+56个字节,K为整数。
    具体补位操作:补一个1,然后补0至满足上述要求。
    补数据长度:
    用一个64位的数字表示数据的原始长度B,把B用两个32位数表示。这时,数
    据就被填补成长度为512位的倍数。
    初始化MD5参数:
    四个32位整数 (A,B,C,D) 用来计算信息摘要,初始化使用的是十六进制表
    示的数字
    A=0X01234567
    B=0X89abcdef
    C=0Xfedcba98
    D=0X76543210

    处理位操作函数:
    X,Y,Z为32位整数。
    F(X,Y,Z) = X&Y|NOT(X)&Z
    G(X,Y,Z) = X&Z|Y?(Z)
    H(X,Y,Z) = X xor Y xor Z
    I(X,Y,Z) = Y xor (X|not(Z))

    主要变换过程:
    使用常数组T[1 ... 64], T[i]为32位整数用16进制表示,数据用16个32位
    的整数数组M[]表示。
    具体过程如下:

    /* 处理数据原文 */
    For i = 0 to N/16-1 do

    /*每一次,把数据原文存放在16个元素的数组X中. */
    For j = 0 to 15 do
    Set X[j] to M[i*16+j].
    end /结束对J的循环

    /* Save A as AA, B as BB, C as CC, and D as DD.
    */
    AA = A
    BB = B
    CC = C
    DD = D

    /* 第1轮*/
    /* 以 [abcd k s i]表示如下操作
    a = b + ((a + F(b,c,d) + X[k] + T[i]) <<< s). */

    /* Do the following 16 operations. */
    [ABCD 0 7 1] [DABC 1 12 2] [CDAB 2 17 3] [BCDA 3
    22 4]
    [ABCD 4 7 5] [DABC 5 12 6] [CDAB 6 17 7] [BCDA 7
    22 8]
    [ABCD 8 7 9] [DABC 9 12 10] [CDAB 10 17 11] [BCDA
    11 22 12]
    [ABCD 12 7 13] [DABC 13 12 14] [CDAB 14 17 15]
    [BCDA 15 22 16]

    /* 第2轮* */
    /* 以 [abcd k s i]表示如下操作
    a = b + ((a + G(b,c,d) + X[k] + T[i]) <<< s). */
    /* Do the following 16 operations. */
    [ABCD 1 5 17] [DABC 6 9 18] [CDAB 11 14 19] [BCDA
    0 20 20]
    [ABCD 5 5 21] [DABC 10 9 22] [CDAB 15 14 23]
    [BCDA 4 20 24]
    [ABCD 9 5 25] [DABC 14 9 26] [CDAB 3 14 27] [BCDA
    8 20 28]
    [ABCD 13 5 29] [DABC 2 9 30] [CDAB 7 14 31] [BCDA
    12 20 32]

    /* 第3轮*/
    /* 以 [abcd k s i]表示如下操作
    a = b + ((a + H(b,c,d) + X[k] + T[i]) <<< s). */
    /* Do the following 16 operations. */
    [ABCD 5 4 33] [DABC 8 11 34] [CDAB 11 16 35]
    [BCDA 14 23 36]
    [ABCD 1 4 37] [DABC 4 11 38] [CDAB 7 16 39] [BCDA
    10 23 40]
    [ABCD 13 4 41] [DABC 0 11 42] [CDAB 3 16 43]
    [BCDA 6 23 44]
    [ABCD 9 4 45] [DABC 12 11 46] [CDAB 15 16 47]
    [BCDA 2 23 48]

    /* 第4轮*/
    /* 以 [abcd k s i]表示如下操作
    a = b + ((a + I(b,c,d) + X[k] + T[i]) <<< s). */
    /* Do the following 16 operations. */
    [ABCD 0 6 49] [DABC 7 10 50] [CDAB 14 15 51]
    [BCDA 5 21 52]
    [ABCD 12 6 53] [DABC 3 10 54] [CDAB 10 15 55]
    [BCDA 1 21 56]
    [ABCD 8 6 57] [DABC 15 10 58] [CDAB 6 15 59]
    [BCDA 13 21 60]
    [ABCD 4 6 61] [DABC 11 10 62] [CDAB 2 15 63]
    [BCDA 9 21 64]

    /* 然后进行如下操作 */
    A = A + AA
    B = B + BB
    C = C + CC
    D = D + DD

    end /* 结束对I的循环*/

    输出结果。

    http://help.liangjing.org/Tools/MD5.aspx

               

    给我老师的人工智能教程打call!http://blog.csdn.net/jiangjunshow

    这里写图片描述
    展开全文
  • compare_md5_s.rar

    2020-05-25 15:45:52
    主要功能为:1,计算文件夹下所有文件的MD5值,并输出到MD5_file.txt文件; 2,在不同(也可相同电脑比较不同版本)电脑上,比较该文件夹下的文件是否存在增删改,以及文件名修改的变化。比较结果 eg: new add file...
  • MD5-Hash值计算工具

    2015-05-13 15:11:58
    该工具用于计算文件的MD5值,根据MD5值可以判断从某网站下载的文件是否被修改过。解压压缩包后,运行exe文件就可以使用。
  • md5解密小工具

    2015-12-14 09:26:42
    打开MD5_SSE2.exe,输入MD5值,按回车即可 高级方法: 用命令行进入MD5_SSE2所在目录 执行MD5_SSE2 <MD5值> <配置文件名> 注意事项:请将本程序放在英文路径下,放在中文路径下可能会出现问题 关于配置文件: 配置文件...
  • md5 windows命令行工具

    2017-01-12 13:12:34
    一个可以在命令行执行md5的小工具
  • C# MD5加密源码

    千次阅读 2016-06-06 10:42:42
    getMD5.exe(拖动任意文件至工具、或在工具中输入字符串,获取MD5值) 工具源码 MD5加密源码:(加密源码源自网络,做了部分修改精简) using System; using System.Collections.Generic; using System.IO; ...
  • MD5加密技术

    千次阅读 2014-04-23 09:46:34
    前几天,在看OpenVXI3.4的时候,偶然发现了几个奇怪的文件,那就是OpenVXI-3.4\src\cache下面的,base64.c,base64.h,md5.c,md5.h。既然有人把源代码给出来了,不妨花点时间看一下。感觉挺有意思,和大家分享一下。先来...
  • VB-MD5校验源码.zip

    2016-08-19 11:09:11
    MD5MD5校验值。 SHA1:安全哈希算法值。 CRC32:CRC校验值。 隐藏主窗口:隐藏好压主窗口以方便鼠标拖拽运算。校验窗口始终显示在最前端。 按钮功能: 浏览按钮:弹出文件浏览对话框。可选择一个或多个文件。...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 31,612
精华内容 12,644
关键字:

exemd5修改