免费注册 查看新帖 |

Chinaunix

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

在python 里 如何用sha计算值的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-12-10 17:28 |只看该作者 |倒序浏览
如何计算,不知道python怎么工作的,
# attribute as turning the action into a critical action?
                if "preserve" in self.attrs and os.path.isfile(final_path):
                        cfile = file(final_path)
                        chash = sha.sha(cfile.read()).hexdigest()

在这的一部分:不理解这个 chash是怎么算出来的,我知道一个文件的sha1值。不理解chash语句是什么意思。查看定义知道python的sha有hexdigest() 前面的sha.sha()不明白。

源码部分: http://cr.opensolaris.org/~rajku ... les/actions/file.py

顺便问下,同一个目录下有test.py 和test.ypc ,都是可执行的文件,被调用的时候,选择哪个呢,两者如何转换?

论坛徽章:
0
2 [报告]
发表于 2009-03-27 11:49 |只看该作者

回复 #1 jklyekai 的帖子

if "preserve" in self.attrs and os.path.isfile(final_path):
                        cfile = file(final_path)
                        chash = sha.sha(cfile.read()).hexdigest()
第一步:判断被校验的文件是否存在
第二步:打开文件, 这里应该用二进制打开方式:cfile = file(final_path, ‘rb’)
第三步:cfile.read(),表示将文件的内容读取到内存中,调用python的校验函数sha.sha()对刚才读取到的文件内容进行校验
          hexdigest()将刚才校验的结果用字符串输出

你这里有两个问题:
第一,打开文件方式应该用二进制方式
第二,你读文件的方式为一次性将文件全部读到内存中,当文件太大时,内存不够,程序会崩掉。建议迭代校验

示例:
import sha
def get_sha1sum(path):
    f = file(path, 'rb')
    m = sha.sha()
    while True:
        l = f.read(1024)
        if len(l) == 0:
            break
        else:
            m.update(l)
    s = m.hexdigest()
    f.close()
    return s


你可以先判断文件是否存在,然后用上面的函数得到sha1值,
上面是迭代的,每次读取1024个字节进行校验,等校验完毕后,返回结果字符串
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP