- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
是否可以使用 FileReader API 和 onprogress 事件访问随 HTML5 传入的数据?
如果是这样,是否有 MD5 或其他快速散列算法的“在线”版本,以便我可以在文件完全读取之前开始计算散列值?
我想在客户端计算哈希值,并在发送整个文件之前只将哈希值发送到服务器,以便在启动文件上传之前检查重复项。
目前我不关心对旧版浏览器的支持。
编辑:我知道哈希冲突并不能保证文件重复,唯一可以确定的方法是逐字节检查,这意味着无论如何我都必须上传文件。概率很低,我愿意冒这个风险;最坏的情况我会提示用户说“这个文件似乎已经在服务器上了;你确定要上传它吗?”
最佳答案
is there an "online" version of MD5 or other fast hashing algorithm so that I can begin computing the hash before the file is fully read?
是的,您可以使用 sjcl如果你想使用 SHA。 sjcl 没有对 MD5 的 native 支持,因此您必须自己编写它(尽管我确信其他人已经这样做了)。 CryptoJS具有 native MD5 支持,但速度明显较慢。
I recognize that a hash collision does not guarantee a duplicate file [...] The probability is low enough that I'm willing to take this risk;
与自然发生碰撞相比, meteor 撞击地球并终结人类生命(从而完全不需要散列)的概率足够低。当然,除非用户故意制造碰撞,因为 MD5 的抗碰撞性已被破坏。
这是一个现场demo 我认为您要完成的任务,减去“访问数据”部分。我不确定这是否可能。这是我很久以前写的,它使用 CryptoJS,所以性能不是很好,但它完成了工作。重要的 block 是:
function handleFileSelect(evt)
{
evt.stopPropagation();
evt.preventDefault();
var files = evt.target.files || evt.dataTransfer.files; // FileList object.
for (var i=0, file; file = files[i]; ++i)
{
// this creates the FileReader and reads stuff as text
var fr = new FileReader();
fr.onload = (function(theFile) {
return function (e) {
var hashes = parsePseudoBuffer(e.target.result);
document.getElementById('output').innerHTML += '<br />' + theFile.name + '<br />'
+ 'MD5: ' + hashes.md5 + '<br />' + 'SHA1: ' + hashes.sha1 + '<br />' ;
};
}) (file);
fr.readAsArrayBuffer(file); // ArrayBuffer
}
}
function parsePseudoBuffer(result)
{
var buffs = new Uint8Array(result); // buffer thingie
var md5 = CryptoJS.algo.MD5.create();
var sha1 = CryptoJS.algo.SHA1.create();
var bufsize = 8 * 1024; // 8K buffer
for (var bstart=0, bend=bufsize; bstart < buffs.length; bstart+=bufsize, bend+= bufsize)
{
var data = CryptoJS.lib.WordArray.create(buffs.subarray(bstart, bend));
md5.update(data);
sha1.update(data);
}
md5 = md5.finalize();
sha1 = sha1.finalize();
return {'md5': md5, 'sha1': sha1} ;
}
关于javascript - 在线/流媒体MD5算法?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18885655/
我想在 md-toolbar 中使用 mf-tabs,我使用 Sithdown 在 https://github.com/angular/material/issues/1076 中提供的解决方案 它
我是新手,我设法用服务提供的数据实现了我的 md-table。现在我正在尝试实现过滤器、排序和分页功能,但我认为我做错了什么。 这是我的组件: import { Component, OnInit,
我必须打开一个 md-dialog,其中包含一个带有两个选项卡的 md-tab-group。 md-dialog 可以从两个按钮打开,这两个按钮应该打开相应的选项卡。打开 md-dialog 的模板:
我正在尝试做这样的事情: {{item}}
我正在尝试使用 md-datepicker 遍历一个月的时间间隔,因此我创建了这个 codepen 示例以便更好地演示: http://codepen.io/anon/pen/ygBGOg 当单击“P
这是关于 Codepen 的例子. 我正在设置 md-row-height="30px" 然后计算 md-rowspan 使其等于元素数 + 1。(头部加一) {{ t
当我频繁切换 md-tabs 时,Md-tabs 切换正确但多个 md-tab-item 元素同时具有“md-active”类,所以我看不到选项卡的内容是事件的,因为它与其右侧选项卡的内容重叠。 据我
我想将操作放在同一数据行上,我有两个操作,为此我使用按钮和图标作为下面的代码。 {{item.codigo}} {{it
在我的对象列表中,我可以激活/非事件对象。因此,一个图标执行事件操作,另一个图标执行非事件操作,并且两者都在同一个 md-list 中。 This is what i'm tring to do 代码
如前所述 Angular-Material md-autocomplete's documentation : The md-autocomplete uses the the md-virtual-
我也在使用 Angular 1 和 Angular Material 。我想在 ng-repeat 中使用 md-subheader 和多个 md-virtual-repeat-container。您
我正在使用 Angular Material 。 当我创建自己的指令并将其添加到 md-tab-label 时,例如 Label 然后自定义指令也应用于一些“md-dummy-tab”。 但是
我在我的项目中使用 Angular Material 有一段时间了。在使用 md-select 时,我遇到了一个问题,即出现重复的 md-option 值错误。 我知道 md-options 采用唯一
我正在根据单选按钮选择设置自动完成验证 md-require-match = true/false。 默认验证是 md-require-match = true 这样用户应该从自动完成列表中选择一个项
这个问题在这里已经有了答案: Changing capitalization of filenames in Git (11 个答案) 关闭 3 年前。 我使用“readme.md”创建了我的存储库
Github有办法吗?在例如 README.md 中包含 md 文件? # Headline Text [include](File:load_another_md_file_here.md) 它不应
我正在使用 AngularJs 开发这个动态过滤系统,并试图找出如何将 color 和 size 选项转换为在两个下拉列表中(每个类别一个)。 我尝试了以下代码,该代码成功添加了下拉列表以及选择框中的
var app = angular.module('tabsDemo', ['ngMaterial']); app.controller('TabsController',tabsController
在 md-tab 指令内嵌套 md-select 和搜索输入时遇到问题。 有两个问题: 选择框展开后,必须向上滚动才能查看搜索输入 搜索输入实际上不接受任何文本 我做了一个codepen为了更好地说明
我正在尝试处理这个片段,其中自动完成功能嵌入在芯片中。但从自动完成中选择的项目不会转换为筹码。 自动完成的数据采用以下方式:{name:"John Doe", id:"1"} 哪里错了,请指教。 问候
我是一名优秀的程序员,十分优秀!