2016-03-02 109 views
1

我测试过md5,sha1,crc32的速度,结果显示md5比sha1慢,我对它感到困惑,因为sha1比md5更复杂。为什么md5比py1慢sha1 2.7.11

我执行我的测试Python脚本哈希PNG图像(你可以使用图像任何你想要的)10000次,如: crc_vs_md5.py C:\用户\ bigwalnut \桌面\ def.png 10000

结果(单位:s): MD5:0.122737341241 SHA1:0.0984247229759 CRC32:0.0577822398549

下面是代码:

from hashlib import md5, sha1 
from zlib import crc32 
import sys 
import time 

numberoftime = 0 
content = None 

def getMd5(): 
    for x in range(0, numberoftime): 
     mdfive = md5() 
     mdfive.update(content) 
     mdfive.hexdigest() 

def getSha1(): 
    for x in range(0, numberoftime): 
     sha1Obj = sha1() 
     sha1Obj.update(content) 
     sha1Obj.hexdigest() 


def getCrc32(): 
    for x in range(0, numberoftime): 
     crc32(content) & 0xffffffff 


if len(sys.argv) < 3: 
    print('You must enter: filename, numberoftime') 
    exit(1) 
elif len(sys.argv) > 3: 
    print('Only filename, numberoftime is permitted') 
    exit(1) 

filename = sys.argv[1] 
numberoftime = int(sys.argv[2]) 
print filename, numberoftime 

with open(filename, 'rb') as f: 
    content = f.read() 

start = time.clock() 
getMd5() 
stop = time.clock() 
print "md5: ", stop - start 

start = time.clock() 
getSha1() 
stop = time.clock() 
print "sha1: ", stop - start 

start = time.clock() 
getCrc32() 
stop = time.clock() 
print "crc32: ", stop - start 
+0

[此链接上的结果](http://atodorov.org/blog/2013/02/05/performance-test-md5-sha1-sha256-sha512/)与您的冲突。 – Selcuk

+1

了解[timeit](https://docs.python.org/2/library/timeit.html)以获得更准确结果的好时机。 – Kupiakos

+0

@Selcuk,对不起,我写了一个错误的标题,在我的测试中,md5比sha1慢。 –

回答

0

的Python借用OpenSSL的PR对于大多数密码学目的来说是潜在的;虽然这不是明确的,但this post意味着OpenSSL开发人员知道MD5已经损坏,但可能没有花费太多精力来优化MD5,而SHA1则进行了大量优化; MD5在算法上可能会更简单,但如果代码的优化程度不如SHA1代码,那么已经很小的优势MD5就不会显着。

On another post comparing OpenSSL's MD5 and SHA1 implementations (without the Python wrapping),它看起来像核心OpenSSL在SHA1通常更快,虽然它的版本/内部版本有所不同(在OSX 10.8和10.10上SHA1更快,10.9上更慢)。