js 根据文件流判断文件类型

function getFileType(file) {
    // 获取文件头信息
    const reader = new FileReader();
    reader.readAsArrayBuffer(file.slice(0, 4));
    return new Promise(resolve => {
        reader.onloadend = () => {
            const buffer = reader.result;
            const header = new Uint8Array(buffer);
            let type = 'unknown';

            // 判断常见图片格式
            if (header[0] === 0xff && header[1] === 0xd8) {
                type = 'image/jpeg';
            } else if (header[0] === 0x89 && header[1] === 0x50 && header[2] === 0x4e && header[3] === 0x47) {
                type = 'image/png';
            } else if (header[0] === 0x47 && header[1] === 0x49 && header[2] === 0x46 && header[3] === 0x38) {
                type = 'image/gif';
            } else if (header[0] === 0x42 && header[1] === 0x4d) {
                type = 'image/bmp';

                // 判断常见文档格式
            } else if (header[0] === 0x25 && header[1] === 0x50 && header[2] === 0x44 && header[3] === 0x46) {
                type = 'application/pdf';
            } else if (header[0] === 0x50 && header[1] === 0x4b && header[2] === 0x03 && header[3] === 0x04) {
                type = 'application/zip';
            } else if (header[0] === 0x7b && header[1] === 0x5c && header[2] === 0x72 && header[3] === 0x74) {
                type = 'text/rtf';
            } else if (header[0] === 0x50 && header[1] === 0x4b && header[2] === 0x53 && header[3] === 0x20) {
                type = 'application/vnd.ms-powerpoint';

                // 判断常见视频格式
            } else if (header[0] === 0x52 && header[1] === 0x49 && header[2] === 0x46 && header[3] === 0x46) {
                const format = new DataView(buffer.slice(8, 12)).getUint32(0, false);
                if (format === 0x5741) {
                    type = 'video/x-ms-wmv';
                } else if (format === 0x4156) {
                    type = 'video/x-msvideo';
                } else if (format === 0x4852) {
                    type = 'video/mp4';
                }

                // 其他类型
            } else if (header[0] === 0x47 && header[1] === 0x49 && header[2] === 0x46 && header[3] === 0x38) {
                type = 'image/gif';
            } else if (header[0] === 0x46 && header[1] === 0x4c && header[2] === 0x56 && header[3] === 0x01) {
                type = 'video/x-flv';
            }

            resolve(type);
        };
    });
}

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值