Vue獲取圖片MD5的方法詳解
背景
計(jì)算圖片的MD5可以將其作為圖片的唯一標(biāo)識(shí),從而優(yōu)化對(duì)圖片的存儲(chǔ)和檢索效率,還可以對(duì)圖片進(jìn)行有效的去重。
名詞解釋
哈希函數(shù)
哈希函數(shù)是一種數(shù)學(xué)函數(shù),也稱散列函數(shù)。它接受任意長度的輸入,并可以將其轉(zhuǎn)換為固定長度的隨機(jī)字母和數(shù)字組成的字符串。由此函數(shù)計(jì)算的值具有不可逆性,即不能通過逆向演算回原本的數(shù)值,可以有效用于加密。
MD5
MD5是一種廣泛使用的哈希函數(shù),MD5算法會(huì)將圖片/文件的二進(jìn)制數(shù)據(jù)作為輸入,計(jì)算出一個(gè)128位的哈希值,可以用于校驗(yàn)文件的完整性和唯一性。
MD5工具--spark-md5
安裝:npm install --save spark-md5
如果使用typeScript需要繼續(xù)安裝對(duì)應(yīng)的類型:npm install --save @types/spark-md5
使用import SparkMD5 from 'spark-md5';
獲取本地上傳圖片的MD5
計(jì)算MD5,重要的是獲取文件的二進(jìn)制數(shù)據(jù)
如果你使用的是原生的<input type="file">,則需要在change事件中找到e.target.files[0]文件
如果使用的是UI組件庫,則一般獲取file.raw
<input type="file" @change="changeFile" />
const changeFile = (e) => {
const file = e.target.files[0];
const fileReader = new FileReader();
const spark = new SparkMD5.ArrayBuffer();
fileReader.readAsArrayBuffer(file);
fileReader.onload = (f) => {
spark.append(f.target.result);
const md5 = spark.end();
console.log('md5', md5);
};
};
運(yùn)行結(jié)果:

獲取支持跨域的網(wǎng)絡(luò)圖片的MD5
fetch獲取
首先使用fetch API獲取圖片,然后將其轉(zhuǎn)換為blob對(duì)象。然后,我們使用FileReader的readAsArrayBuffer方法將blob轉(zhuǎn)換為ArrayBuffer
const getFileMd5 = () => {
const fileReader = new FileReader();
const spark = new SparkMD5.ArrayBuffer();
// 圖片url 圖片來源必須支持跨域
fetch('https://picsum.photos/536/354')
.then((response) => response.blob())
.then((blob) => {
fileReader.readAsArrayBuffer(blob);
fileReader.onload = (e) => {
spark.append(e.target?.result as ArrayBuffer);
const md5 = spark.end();
console.log('md5', md5);
};
})
.catch(console.error);
};
運(yùn)行結(jié)果:

Image對(duì)象獲取
此方法需要將Image復(fù)制到canvas上面進(jìn)行canvas.toDataURL(),此處涉及到<img>標(biāo)簽的特性:
一般情況下,<img>進(jìn)行圖片加載是不會(huì)發(fā)送網(wǎng)絡(luò)請(qǐng)求的,出于安全考慮,沒有通過CORS授權(quán)獲取的圖像是不允許在canvas中使用的。
因此需要在<img>標(biāo)簽上加上crossOrigin屬性
更多屬性相關(guān)內(nèi)容可查看該鏈接:developer.mozilla.org/zh-CN/docs/Web/HTML/Element/img

<img class="testImg" src="https://picsum.photos/536/354" crossOrigin="anonymous" />
const getFileMd5 = () => {
// 找到圖片對(duì)象
const image = document.querySelectorAll('.testImg')[0] as HTMLImageElement;
// 將canvas上的內(nèi)容轉(zhuǎn)換為一個(gè)數(shù)據(jù)URL,該URL代表了canvas 的像素?cái)?shù)據(jù)
const canvas = document.createElement('canvas');
canvas.width = image.width;
canvas.height = image.height;
const ctx = canvas.getContext('2d');
ctx?.drawImage(image, 0, 0, canvas.width, canvas.height);
const dataURL = canvas.toDataURL();
// 將dataUrl數(shù)據(jù)轉(zhuǎn)換為blob
const arr = dataURL.split(',');
const mimeList = arr[0].match(/:(.*?);/);
if (!mimeList || !mimeList.length) return;
const mime = mimeList[1];
const bstr = atob(arr[1]);
let n = bstr.length;
const u8arr = new Uint8Array(n);
while (n--) {
u8arr[n] = bstr.charCodeAt(n);
}
const blob = new Blob([u8arr], { type: mime });
// 計(jì)算md5
const fileReader = new FileReader();
const spark = new SparkMD5.ArrayBuffer();
fileReader.readAsArrayBuffer(blob);
fileReader.onload = (e) => {
spark.append(e.target?.result as ArrayBuffer);
const md5 = spark.end();
console.log('md5', md5);
};
};
// 方法調(diào)用:要保證圖片已經(jīng)加載完 可以使用setTimeout或者nextTick setTimeout(() => getFileMd5(), 0);
獲取不支持跨域的網(wǎng)絡(luò)圖片的MD5
此情況建議由服務(wù)端進(jìn)行圖片md5的計(jì)算
服務(wù)端設(shè)置響應(yīng)頭
需要服務(wù)端設(shè)置響應(yīng)頭 Access-Control-Allow-Origin: *
通過node轉(zhuǎn)發(fā)獲取
待補(bǔ)充
到此這篇關(guān)于Vue獲取圖片MD5的方法詳解的文章就介紹到這了,更多相關(guān)Vue獲取圖片MD5內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue echarts封裝組件需求分析與實(shí)現(xiàn)
在平常的項(xiàng)目中,echarts圖表我們也是使用的非常多的,通常我們從后端拿到數(shù)據(jù),需要在圖表上動(dòng)態(tài)的進(jìn)行呈現(xiàn),接下來我們就模擬從后端獲取數(shù)據(jù)然后進(jìn)行呈現(xiàn)的方法,這篇文章主要介紹了Vue echarts封裝組件需求分析與實(shí)現(xiàn)2022-10-10
vue如何實(shí)現(xiàn)點(diǎn)擊空白區(qū)域關(guān)閉彈窗
這篇文章主要介紹了vue如何實(shí)現(xiàn)點(diǎn)擊空白區(qū)域關(guān)閉彈窗問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2025-04-04
vue3使用別名報(bào)錯(cuò)問題的解決辦法(vetur插件報(bào)錯(cuò)問題)
最近在寫一個(gè)購物網(wǎng)站使用vue,使用中遇到了問題,下面這篇文章主要給大家介紹了關(guān)于vue3使用別名報(bào)錯(cuò)問題的解決辦法,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-07-07
Vue實(shí)現(xiàn)雙token無感刷新的示例代碼
這篇文章主要介紹了Vue實(shí)現(xiàn)雙token無感刷新,雙token機(jī)制,尤其是指在OAuth 2.0授權(quán)協(xié)議中廣泛使用的access token(訪問令牌)和refresh token(刷新令牌)組合,文中通過代碼示例講解的非常詳細(xì),需要的朋友可以參考下2024-03-03
vue-element內(nèi)table插入超鏈接a標(biāo)簽的使用
在Vue Element的table組件中插入超鏈接,可以使用<el-link>標(biāo)簽替代傳統(tǒng)的<a>標(biāo)簽,實(shí)現(xiàn)更加整潔的UI設(shè)計(jì),具體操作是替換原有的<span>標(biāo)簽,直接使用<el-link>進(jìn)行超鏈接的插入,使得鏈接樣式與Element UI保持一致2024-09-09
Vue+jsPlumb實(shí)現(xiàn)連線效果(支持滑動(dòng)連線和點(diǎn)擊連線)
jsPlumb 是一個(gè)比較強(qiáng)大的繪圖組件,它提供了一種方法,主要用于連接網(wǎng)頁上的元素。本文將利用jsPlumb實(shí)現(xiàn)連線效果,同時(shí)支持滑動(dòng)連線和點(diǎn)擊連線,感興趣的可以了解一下2023-01-01
詳解vue中父子組件傳遞參數(shù)props的實(shí)現(xiàn)方式
這篇文章主要給大家介紹了在vue中,父子組件傳遞參數(shù)?props?實(shí)現(xiàn)方式,文章通過代碼示例介紹的非常詳細(xì),對(duì)我們的學(xué)習(xí)或工作有一定的參考價(jià)值,需要的朋友可以參考下2023-07-07

