- 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/
创建使用.NET框架的asp.net页面时,访问该页面的客户端是否需要在其计算机上安装.NET框架? IE。用户访问www.fakesite.com/default.aspx,如果他们没有安装框架,他
我阅读了很多不同的博客和 StackOverflow 问题,试图找到我的问题的答案,但最后我找不到任何东西,所以我想自己问这个问题。 我正在构建一个应用程序,其中有一个长时间运行的工作线程,它执行一些
已锁定。这个问题及其答案是locked因为这个问题是题外话,但却具有历史意义。目前不接受新的答案或互动。 我一直想知道为什么微软为这样一个伟大的平台选择了一个如此奇怪的、对搜索引擎不友好的名称。他们就
.Net Framework .Net .NET Standard的区别 1、.NET Framework 在未来.NET Framework或许成为过去时,目前还是有很多地方在使用的。这一套
如果有选择的话,您会走哪条路? ASP.NET Webforms + ASP.NET AJAX 或 ASP.NET MVC + JavaScript Framework of your Choice
我有一个 Web 服务,它通过专用连接通过 https 使用第三方 Web 服务,我应用了 ServicePointManager.ServerCertificateValidationCallbac
为什么我应该选择ASP.NET Web Application (.NET Framework)而不是ASP.NET Core Web Application (.NET Framework)? 我在
我在网络上没有找到任何关于包含 .NET Standard、.NET Core 和 .NET Framework 项目的 .NET 解决方案的公认命名约定。 就我而言,我们在 .NET 框架项目中有以
.NET Compact 是 .NET 的完美子集吗? 假设我考虑了屏幕大小和其他限制并避免了 .NET Compact 不支持的类和方法,或者 .NET Compact 是一个不同且不兼容的 GUI
我已经阅读了所有我能找到的关于 connectionManagement 中的 maxconnection 设置的文章:即 http://support.microsoft.com/kb/821268
我现在正在使用asp.net mvc,想知道使用内置的Json或 Json.Net哪个是更好的选择,但我不确定一个人是否比另一个人有优势。 另外,如果我确实选择沿用Json.Net的路线,那么我应该选
在 Visual Studio 中,您至少可以创建三种不同类型的类库: 类库(.NET Framework) 类库(.NET 标准) 类库(.NET Core) 虽然第一个是我们多年来一直使用的,但我
.NET 和 ASP.NET 之间有什么区别?它们有什么关系? 最佳答案 ASP.Net 基于 .Net 框架构建,提供有关 Web 开发的附加功能。 你可以去看看wikipedia article
在安装更高版本(3.0)之前,我需要安装.net框架1.1和2.0吗?或者单独安装 3.0 框架就足够了,并为在早期框架版本上编写的软件提供支持?谢谢 ,丽然 最佳答案 不,您不必安装以前的框架。 我
我正在开发一个项目,人们可以“更新”类别,例如更改类别的名称。我收到以下消息 This is called after clicking update 按钮 with the SQL statemen
.NET 类 System.Net.CookieContainer 线程安全吗? --更新:交 key 答复-- 是否有任何方法可以确保异步请求期间修改的变量(即 HttpWebRequest.Coo
我正在使用 JScript.NET 在我编写的 C# WinForms 应用程序中编写脚本。它工作得很好,但我只是尝试在脚本中放置一些异常处理,但我无法弄清楚如何判断我的 C# 代码抛出了哪种类型的异
我需要你的帮助, 比如我有一个小数类型的变量,我想这样取整。 例如 3.0 = 3 3.1 = 4 3.2 = 4 3.3 = 4 3.4 = 4 3.5 = 4 3.6 = 4 3.7 = 4 3.
我使用过这样的代码:http://msdn.microsoft.com/en-us/library/dw70f090.aspx在 ASP.NET 中工作之前访问数据库(2-3 年前)。我没有意识到我正
自 ConfigurationManager .NET Standard 中不存在,检索正在执行的程序集的应用程序设置的最佳方法是什么,无论是 web.config或 appSettings.{env
我是一名优秀的程序员,十分优秀!