正常情况下,文件都有后缀名,例如:xxx.gif, xxxx.avi。但也存在文件后缀名去掉的情况,虽然如此,去掉文件的后缀名,并不会影响文件本身的内容。所以在文件的数据中,有其他的方式能够标识出文件的类型。
, _ u- B1 D9 y" M" ^4 h- \ 在编程中,把标识文件格式的常量称为 Magic Number, 原名叫做:File Signatures(文件签名)。
+ Z2 s6 D; K2 }1 p9 m' dMagic Number 在编程中有以下三类使用:
0 u4 w, h/ z# Z: `: R! f- 无法解释其意义的唯一值或者在程序中多次被引用但又可被命名常数所替代的值。
- 用来识别文本类型的一个常量数值或字符。
- 不易被误解为其他意义的特有值,如全局唯一标识符。6 I2 [ i% \& v9 u, i, P3 {
利用 Magic Number 判断文件类型: R5 k8 _" i4 T' J' F4 d; L8 p7 m
1、请求获取文件数据,并转成 Array Buffer
4 _0 ]8 ~0 F8 o( k2 Bfunction loadFile(url) {
return new Promise((resolve, reject) => {
const xhr = new XMLHttpRequest()
xhr.onreadystatechange = function() {
if (xhr.readyState === 4) {
resolve(xhr)
}
}
xhr.onerror = reject
xhr.open('GET', url, true)
xhr.responseType = 'arraybuffer'
xhr.send('')
})
} 2、 buffer 转 16 进制字符串
$ ?/ Z+ ]* R; C' m+ Z# j, Tfunction buf2hex(buffer) {
return Array.prototype.map.call(new Uint8Array(buffer), x => ('00' + x.toString(16)).slice(-2)).join('')
} 3、根据 16 进制字符串获取文件头,判断文件类型) R7 [: A3 y' W( M$ S6 V9 f
function getFileType(url) {
loadFile(url).then(xhr => {
const hex = buf2hex(xhr.response)
console.log(hex)
// todo....
})
} 测试:& z6 S# [, @* ?- U+ L+ p- u
! \( i+ `( p0 n. ~ j; ]- g3 F
常见文件头:6 N0 x+ S+ l3 z8 y) J9 l
|