使用HASH算法实现文件的断点续传

一个已有的大文件,如何做到客户端的快速下载。使用断点续传技术,充分利用网络带宽和CPU。

思路:把大文件按照一定算法分割成很多部分Part文件,用MD5算法签名做各个part部分的验证值,客户端下载后用同一个key对下载的part做MD5,结果一样,就完成这一个part的下载,不一样则丢掉继续重新下载。最后下载完毕后再把各个part合并成大文件。对于下载情况,可以自己设计一个表结构来对每一个客户端的下载进行维护。客户端的文件的断点续传上传也是一样的思路。


Hash算法到底有什么用呢?   Hash算法在信息安全方面的应用主要体现在以下的3个方面:   1) 文件校验   我们比较熟悉的校验算法有奇偶校验和CRC校验,这2种校验并没有抗数据篡改的能力,它们一定程度上能检测并纠正数据传输中的信道误码,但却不能防止对数据的恶意破坏。   MD5 Hash算法的"数字指纹"特性,使它成为目前应用最广泛的一种文件完整性校验和(Checksum)算法,不少Unix系统有提供计算md5 checksum的命令。   2) 数字签名   Hash 算法也是现代密码体系中的一个重要组成部分。由于非对称算法的运算速度较慢,所以在数字签名协议中,单向散列函数扮演了一个重要的角色。对 Hash 值,又称"数字摘要"进行数字签名,在统计上可以认为与对文件本身进行数字签名是等效的。而且这样的协议还有其他的优点。   3) 鉴权协议   如下的鉴权协议又被称作"挑战--认证模式:在传输信道是可被侦听,但不可被篡改的情况下,这是一种简单而安全的方法。编辑本段hash函数 - Hash算法的用处  Hash算法在信息安全方面的应用主要体现在以下的3个方面:   1) 文件校验   我们比较熟悉的校验算法有奇偶校验和CRC校验,这2种校验并没有抗数据篡改的能力,它们一定程度上能检测并纠正数据传输中的信道误码,但却不能防止对数据的恶意破坏。   MD5 Hash算法的"数字指纹"特性,使它成为目前应用最广泛的一种文件完整性校验和(Checksum)算法,不少Unix系统有提供计算md5 checksum的命令。   2) 数字签名   Hash 算法也是现代密码体系中的一个重要组成部分。由于非对称算法的运算速度较慢,所以在数字签名协议中,单向散列函数扮演了一个重要的角色。对 Hash 值,又称"数字摘要"进行数字签名,在统计上可以认为与对文件本身进行数字签名是等效的。而且这样的协议还有其他的优点。   3) 鉴权协议   如下的鉴权协议又被称作"挑战--认证模式:在传输信道是可被侦听,但不可被篡改的情况下,这是一种简单而安全的方法。   以上就是一些关于hash以及其相关的一些基本预备知识。那么在emule里面他具体起到什么作用呢?编辑本段hash函数 - userhash  道理同上,当我们在第一次使用emule的时候,emule会自动生成一个值,这个值也是唯一的,它是我们在emule世界里面的标志,只要你不卸载,不删除config,你的userhash值也就永远不变,积分制度就是通过这个值在起作用,emule里面的积分保存,身份识别,都是使用这个值,而和你的id和你的用户名无关,你随便怎么改这些东西,你的userhash值都是不变的,这也充分保证了公平性。其实他也是一个信息摘要,只不过保存的不是文件信息,而是我们每个人的信息。编辑本段hash函数 - hash文件  我们经常在emule日志里面看到,emule正在hash文件,这里就是利用了hash算法的文件校验性这个功能了,文章前面已经说了一些这些功能,其实这部分是一个非常复杂的过程,目前在ftp,bt等软件里面都是用的这个基本原理,emule里面是采用文件分块传输,这样传输的每一块都要进行对比校验,如果错误则要进行重新下载,这期间这些相关信息写入met文件,直到整个任务完成,这个时候part文件进行重新命名,然后使用move命令,把它传送到incoming文件里面,然后met文件自动删除,所以我们有的时候会遇到hash文件失败,就是指的是met里面的信息出了错误不能够和part文件匹配,另外有的时候开机也要疯狂hash,有两种情况一种是你在第一次使用,这个时候要hash提取所有文件信息,还有一种情况就是上一次你非法关机,那么这个时候就是要进行排错校验了。   关于hash的算法研究,一直是信息科学里面的一个前沿,尤其在网络技术普及的今天,他的重要性越来越突出,其实我们每天在网上进行的信息交流安全验证,我们在使用的操作系统密钥原理,里面都有它的身影,特别对于那些研究信息安全有兴趣的朋友,这更是一个打开信息世界的钥匙,他在hack世界里面也是一个研究的焦点.我是一个门外汉,利用这个周末找了一些资料,胡乱写了一点关于hash的文章,也有不少是我自己的分析,这期间肯定还有不对的地方,还请朋友们多多指出错误,我抛砖引玉希望大家批评指导。

转载自:http://baike.baidu.com/view/604021.htm


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用哈希算法Hash Algorithm)实现快速排序是不可行的。哈希算法是一种将任意长度的数据映射为固定长度的数据的算法,通常用于数据的唯一标识和加密等场合。快速排序是一种基于比较的排序算法,通过比较和交换数组元素的位置来达到排序的目的。哈希算法无法实现比较和交换操作,因此不能用于快速排序。 快速排序的核心思想是选择一个枢轴元素,将数组分成小于等于枢轴元素和大于枢轴元素两部分,然后递归地对左右两部分进行排序。具体实现可以使用多种编程语言和算法,例如使用 C 语言实现的经典快速排序算法如下: ```c void quick_sort(int arr[], int left, int right) { int i, j, pivot, temp; if (left < right) { pivot = left; i = left; j = right; while (i < j) { while (arr[i] <= arr[pivot] && i < right) { i++; } while (arr[j] > arr[pivot]) { j--; } if (i < j) { temp = arr[i]; arr[i] = arr[j]; arr[j] = temp; } } temp = arr[pivot]; arr[pivot] = arr[j]; arr[j] = temp; quick_sort(arr, left, j - 1); quick_sort(arr, j + 1, right); } } ``` 上述代码中,`arr` 表示要排序的数组,`left` 和 `right` 分别表示数组的左右边界。在每次递归中,选择数组第一个元素作为枢轴元素 `pivot`,然后使用双指针法将数组分成小于等于枢轴元素和大于枢轴元素两部分。最后交换枢轴元素和指针 `j` 所指向的元素,然后递归对左右两部分进行排序。 使用哈希算法无法实现上述比较和交换操作,因此无法用于快速排序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值