- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我有以下用例:
增量散列文件不是问题,just call TransformBlock
and TransformFinalBlock
.
问题是我需要共享其起始字节的多个数据散列,但在我调用 TransformFinalBlock
读取第一个 n 的
bytes 我不能继续使用同一个对象进行哈希处理,需要一个新对象。Hash
之后
搜索问题时,我看到 Python以及OpenSSL可以选择为此目的复制哈希对象:
hash.copy()
Return a copy (“clone”) of the hash object. This can be used to efficiently compute the digests of strings that share a common initial substring.
EVP_MD_CTX_copy_ex() can be used to copy the message digest state from in to out. This is useful if large amounts of data are to be hashed which only differ in the last few bytes. out must be initialized before calling this function.
尽我所能搜索,我无法找到库存 C# HashAlgorithm 中的任何内容这将允许我有效地 Clone()
== 复制这样一个对象 before 调用它的 TransformFinalBlock
方法——然后继续散列其余部分克隆的数据。
我找到了一个 C# reference implementation for MD5可以简单地调整以支持克隆(*),但强烈希望使用现有的东西而不是将这样的东西引入代码库。
(*) 事实上,据我所知,任何我费心检查的哈希算法(与加密/解密相反)都是可简单复制的,因为这种算法的所有状态都是摘要的一种形式。
我是不是遗漏了什么,或者标准的 C#/.NET 接口(interface)实际上没有提供复制散列对象的方法?
另一个数据点:
Microsoft 拥有 用于 crypto services 的 native API有一个函数 CryptDuplicateHash
,哪个州的文档,引用:
The CryptDuplicateHash function can be used to create separate hashes of two different contents that begin with the same content.
从 Windows XP 开始就存在。 :-|
请注意。 MD5:用例不是加密敏感的。只是可靠的文件校验和。
最佳答案
我知道这并不完全是您所要求的,但如果这与您要解决的问题相符,那么它是一种替代方法,可以为您提供相同的保证和类似的流媒体性能特征。我过去曾将其用于服务器到服务器的文件传输协议(protocol),其中发送方/接收方并不总是可用/可靠。诚然,我可以控制线路两侧的代码,但我知道你可能无法控制。在那种情况下,请忽略 ;-)
我的方法是设置 1 个 HashAlgorithm 来处理整个文件,另一个 HashAlgorithm 用于散列文件的固定大小的 block ——不是滚动散列(避免你的问题),而是独立的散列。因此,想象一个 1034MB(1 GB + 10 MB)的文件在逻辑上分成 32MB 的 block 。发送方加载文件,同时在文件级和 block 级 HashAlgorithm 上调用 TransformBlock。当它到达 32MB 的末尾时,它在 block 级上调用 TransformFinalBlock,记录该 block 的散列,并为下一个 block 重置/创建一个新的 HashAlgorithm。当它到达文件末尾时,它在文件级和 block 级哈希器上调用 TransformFinalBlock。现在发送方有了一个传输“计划”,其中包括文件名、文件大小、文件哈希以及每个 block 的偏移量、长度和哈希。
它将计划发送给接收者,接收者要么为新文件分配空间(文件长度 % block 大小告诉它最后一个 block 小于 32MB),要么打开现有文件。如果文件已经存在,它会运行相同的算法来计算相同大小块的哈希值。与计划的任何不匹配都会导致它仅向发送者询问这些 block (这将说明尚未传输的 block /全 0 和损坏的 block )。它循环执行此操作(验证、请求 block ),直到没有什么可请求的为止。然后它根据计划检查文件级哈希。如果文件级散列无效但 block 级散列均有效,则可能意味着散列冲突或内存损坏(这两种情况都极为罕见……我使用了 SHA-512)。这允许接收方从不完整的 block 或损坏的 block 中恢复,最坏情况的惩罚是必须再次下载 1 个坏 block ,这可以通过调整 block 大小来抵消。
关于c# - 是否可以复制 .NET HashAlgorithm(用于重复的增量哈希结果)?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26123689/
我有一个 if 语句,如下所示 if (not(fullpath.lower().endswith(".pdf")) or not (fullpath.lower().endswith(tup
然而,在 PHP 中,可以: only appears if $foo is true. only appears if $foo is false. 在 Javascript 中,能否在一个脚
XML有很多好处。它既是机器可读的,也是人类可读的,它具有标准化的格式,并且用途广泛。 它也有一些缺点。它是冗长的,不是传输大量数据的非常有效的方法。 XML最有用的方面之一是模式语言。使用模式,您可
由于长期使用 SQL2000,我并没有真正深入了解公用表表达式。 我给出的答案here (#4025380)和 here (#4018793)违背了潮流,因为他们没有使用 CTE。 我很欣赏它们对于递
我有一个应用程序: void deleteObj(id){ MyObj obj = getObjById(id); if (obj == null) { throw n
我的代码如下。可能我以类似的方式多次使用它,即简单地说,我正在以这种方式管理 session 和事务: List users= null; try{ sess
在开发J2EE Web应用程序时,我通常会按以下方式组织我的包结构 com.jameselsey.. 控制器-控制器/操作转到此处 服务-事务服务类,由控制器调用 域-应用程序使用的我的域类/对象 D
这更多是出于好奇而不是任何重要问题,但我只是想知道 memmove 中的以下片段文档: Copying takes place as if an intermediate buffer were us
路径压缩涉及将根指定为路径上每个节点的新父节点——这可能会降低根的等级,并可能降低路径上所有节点的等级。有办法解决这个问题吗?有必要处理这个吗?或者,也许可以将等级视为树高的上限而不是确切的高度? 谢
我有两个类,A 和 B。A 是 B 的父类,我有一个函数接收指向 A 类型类的指针,检查它是否也是 B 类型,如果是将调用另一个函数,该函数接受一个指向类型 B 的类的指针。当函数调用另一个函数时,我
有没有办法让 valgrind 使用多个处理器? 我正在使用 valgrind 的 callgrind 进行一些瓶颈分析,并注意到我的应用程序中的资源使用行为与在 valgrind/callgrind
假设我们要使用 ReaderT [(a,b)]超过 Maybe monad,然后我们想在列表中进行查找。 现在,一个简单且不常见的方法是: 第一种可能性 find a = ReaderT (looku
我的代码似乎有问题。我需要说的是: if ( $('html').attr('lang').val() == 'fr-FR' ) { // do this } else { // do
根据this文章(2018 年 4 月)AKS 在可用性集中运行时能够跨故障域智能放置 Pod,但尚不考虑更新域。很快就会使用更新域将 Pod 放入 AKS 中吗? 最佳答案 当您设置集群时,它已经自
course | section | type comart2 : bsit201 : lec comart2 :
我正在开发自己的 SDK,而这又依赖于某些第 3 方 SDK。例如 - OkHttp。 我应该将 OkHttp 添加到我的 build.gradle 中,还是让我的 SDK 用户包含它?在这种情况下,
随着 Rust 越来越充实,我对它的兴趣开始激起。我喜欢它支持代数数据类型,尤其是那些匹配的事实,但是对其他功能习语有什么想法吗? 例如标准库中是否有标准过滤器/映射/归约函数的集合,更重要的是,您能
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎与 help center 中定义的范围内的编程无关。 . 关闭 9 年前。 Improve
我一直在研究 PHP 中的对象。我见过的所有示例甚至在它们自己的对象上都使用了对象构造函数。 PHP 会强制您这样做吗?如果是,为什么? 例如: firstname = $firstname;
...比关联数组? 关联数组会占用更多内存吗? $arr = array(1, 1, 1); $arr[10] = 1; $arr[] = 1; // <- index is 11; does the
我是一名优秀的程序员,十分优秀!