前幾天接到一個奇怪的需求,要在web頁面中計算文件的md5值,還好這個項目是只需兼容現代瀏覽器的,不然要坑死了。
其實對文件進行md5,對於后端來說是及其簡單的。比如使用Node.js,只要下面幾行代碼就可以了:
var fs= require('fs'); |
但是對於瀏覽器,如果不能使用HTML5的file api,對文件md5是幾乎不可能的事。如果可以不使用file api,還請哪位大牛給分享一下。
要在瀏覽器中對文件進行md5,基本思路就是使用HTML5的FileReader接口把文件讀取到內存,然后獲取文件的二進制內容,最后再進行md5。
Github中已經有人最這個問題進行研究,其中比較優秀的一個項目就是:js-spark-md5,該項目使用了世界上最快的md5算法。
為了更好的重用代碼,我在js-spark-md5的基礎上封裝了browser-md5-file,可以更方便的使用md5 file。
-
項目地址:browser-md5-file
-
Demo: 查看
使用方法非常簡單:
<script src="bower_components/browser-md5-file/dist/browser-md5-file.js"></script> |
var el = document.getElementById('upload'); |
詳細的使用方法可以查看Github中的文檔。
關於瀏覽器兼容性,由於使用的HTML5 api,所以只能兼容到一下瀏覽器:
- IE10+
- Firefox
- Chrome
- Safari
- Opera
還有一點,由於需要把文件讀取到內存,md5大文件會性能較差。