由汇编内核的MD5算法编写谈代码优化

2016-01-29 12:13 58 1 收藏

由汇编内核的MD5算法编写谈代码优化,由汇编内核的MD5算法编写谈代码优化

【 tulaoshi.com - C语言心得技巧 】

由汇编内核的MD5算法编写谈代码优化
       作者:crazyd

下载本文示例工程
       
       去年为了破解动网论坛,写了一个用于破解动网论坛的md5暴力破解程序(http://tongtian.net/pediy/usr/12/12_662.rar),当时为了提高md5算法的运算速度,就将从VCKBASE下载的C代码md5算法改进了一下,结果成效显著。对于代码改写过程中的一些小心得和大家共享,呵呵,高手就不用看了。

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com)

开始我们做个实验,先打开两个文档附带的程序,一个工程是MD5C,一个工程是MD5ASM,其中MD5C是从VCKBASE下载的md5算法的标准C语言原代码,MD5ASM是我修改后的md5算法原代码。我给这两个工程的main函数里面都添加了一段回朔代码,用来产生0~99999999的数字,然后用这两个工程里面的可执行文件去对每个数字md5加密。好了,经过一段时间的等待后,就可以看到类似的结果了:
               
       MD5ASM工程在我的机器上的结果是181秒,MD5C在我的机器上产生的结果是999秒,呵呵,数字有点怪,不过我看了表的,差不多是这个时间,巨大的差距是怎样产生的,让我们接下来往下看吧。

在开始正题之前,大家需要清楚一件事,就是MD5C里面的代码虽然效率不高,但绝对是优秀的,因为它主要在演示md5的算法,用的是纯粹的C,没有添加任何平台相干的代码,而我改写的MD5ASM是只能够运行于x86上的windows系统中。所以速度是以兼容性来交换的。
       
        一、算法优化
       
       先观察一下MD5C里面的一段代码:

static void Encode (unsigned char *output, unsigned int  *input, unsigned int len){unsigned int i, j;for (i = 0, j = 0; j < len; i++, j += 4) {output[j] = (unsigned char)(input[i] & 0xff);output[j+1] = (unsigned char)((input[i] >> 8) & 0xff);output[j+2] = (unsigned char)((input[i] >> 16) & 0xff);output[j+3] = (unsigned char)((input[i] >> 24) & 0xff);}}

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com)

这是一段将整数数组转换成为字符数组的代码,我们看看它到底做了些什么。假设主函数输入了一个整数0x30313233,那么这个子函数的调用就可以写成下面的样子:

Encode (output, input, 1)

Input指向一个整数数组,数组的第一个元素是0x30313233,我们接下来看函数转换

i=0,j=0output[0]= (unsigned char)(input[0]& 0xff)=0x33output[1]= (unsigned char)(input[0]& 0xff)=0x32output[2]= (unsigned char)(input[0]& 0xff)=0x31output[3]= (unsigned char)(input[0]& 0xff)=0x30i=0,j=4

     
     跳出循环

     output的内存排列顺序为

     +--+--+--+--+--
     |33|32|31|30|
     +--+--+--+--+--
     ^
     output
     
     现在大家注意了,input的排列顺序是什么?由计算机原理可知道,在计算机内部,数据的存放顺序是“高位对应高位,低位对应低位”,0x30313233中的33因为是个位,是低位,所以对应内存单元的最低位,同理30在内存单元的最高位,由此推出0x30313233在数组中的排列顺序为:

+--+--+--+--+--
       |33 32 31 30|
       +--+--+--+--+--
       ^
       input
       
       结果显而易见了,这个函数的功能只是将一个无符号整形数组转换成为了一个无符号字符形数组,作者的目的我虽然不清楚,但是这个地方确实可以优化如下:

output=(unsigned char *)input;

     把这个地方叫作算法的优化可能有点牵强,但是算法的优化确实是最为重要的,比如说搜索算法,如果选择不当,可能要丧失很多的效率。
     
      二、内存拷贝优化
     
     再观察一下MD5C里面的一段代码:

static void MD5_memcpy (unsigned char *output, unsigned int  *input, unsigned int len){  unsigned int i;  for (i = 0; i < len; i++)    output[i] = input[i];}

     这处的为什么要修改是非常明显的,for循环是非常慢的,我们一般可以把类似的代码替换成为C的库函数或者操作系统的标准函数,如:  

CopyMemory ()memcpy()

     这种内存代码你也千万不要尝试自己去实现,那将是一种灾难,在每个操作系统中,内存拷贝可以说是非常频繁的,所以系统的内存拷贝函数基本上都是非常完美的,不信的话你可以自己写一段内存拷贝函数,然后和系统的内

来源:https://www.tulaoshi.com/n/20160129/1485140.html

延伸阅读
md5校验工具怎么用?   第一步:打开MD5校验工具 第二步:将您下载的软件拖到该软件内 第三步: 将您MD5软件生成的校验码与我们官网上公布的校验码做对比。 相同则表示您所下载的软件为合法软件。不同则表示您所下载的软件已被非法改动,请不要安装使用
MD5的全称是Message-Digest Algorithm 5,在90年代初由MIT的计算机科学实验室和RSA Data Security Inc发明,经MD2、MD3和MD4发展而来。 Message-Digest泛指字节串(Message)的Hash变换,就是把一个任意长度的字节串变换成一定长的大整数。请注重我使用了“字节串”而不是“字符串”这个词,是因为这种变换只与字节的值有关,与字...
标签: ASP
/* MD5 Message-Digest Algorithm - JavaScript ' MODIFICATION HISTORY: ' 1.0 16-Feb-2001 - Phil Fresle (sales@frez.co.uk) - Initial Version (VB/ASP code) ' 1.0 21-Feb-2001 - Enrico Mosanghini (erik504@yahoo.com) - JavaScript porting */ function MD5(sMessage) { function RotateLeft(lValue, iShiftBits) { return (lValue<&...
标签: Web开发
其实在ASP.Net编程中,不用调用md5.asp来加密数据。在DotNet中有自带的类:System.Web.Security.HashPasswordForStoringInConfigFile() public string md5(string str,int code) { if(code==16) //16位MD5加密(取32位加密的9~25字符) { return System.Web.Security.FormsAuthentication.HashPasswordForStorin...
标签: Web开发
源码 /**  * 类名:      MD5Digestbr  * 说明:   用来进行密码加密的md5公用参数br  * 编写日期:  2001/03/05br  * 修改者:    br  * 修改信息:  br  * @author     edgarlo edgarlo@c...

经验教程

339

收藏

11
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部