当前位置: 首页 > 编程笔记 >

node.js解决获取图片真实文件类型的问题

哈襦宗
2023-03-14
本文向大家介绍node.js解决获取图片真实文件类型的问题,包括了node.js解决获取图片真实文件类型的问题的使用技巧和注意事项,需要的朋友参考一下

遇到一个需求:假定有一个图片文件,真实的类型为jpg,而有人偷懒把jpg直接复制一张,存为同名的png文件,这样在as3读取文件时不会遇到问题,但手机c++在读取文件时却遇到问题了 - -!

现在就需要写一个程序,遍历所有文件夹下的文件,查找文件格式“不正常”的文件。我们的资源主要是gif、png、jpg,最开始,我到网上找到一篇文章:根据二进制流及文件头获取文件类型mime-type,然后读取文件二进制的头信息,获取其真实的文件类型,对与通过后缀名获得的文件类型进行比较。


var fd = fs.openSync(new_file_path, 'r');

var buffer = new Buffer(8);

var mineType = mime.lookup(new_file_path); var fileType = mime.extension(mineType);

fs.readSync(fd, buffer, 0, 8, 0); var newBuf = buffer.slice(0, 4); var head_1 = newBuf[0].toString(16); var head_2 = newBuf[1].toString(16); var head_3 = newBuf[2].toString(16); var head_4 = newBuf[3].toString(16); var head_iden = head_1 + head_2;

var tempFileType = FILE_TYPE_CONFIG[head_iden]; if (!tempFileType) {     head_iden += head_3;

    tempFileType = FILE_TYPE_CONFIG[head_iden];

    if (!tempFileType) {         var msg = "Unknow fileType " + new_file_path + '-' + fileType;         showLog(msg);         continue;     } }

if (tempFileType != fileType) {     var msg = "Error fileType" + new_file_path + '-' + fileType + '|' + tempFileType + '--正确的图像文件格式';     showLog(msg);

    g_errorFileTypArr.push(msg); }

后来搜索node image相关的信息时,找到这篇文章:node.js module ranking>> (images)

然后筛选到一个模块“node-imageinfo”,写了一个例子进行测试(故意把jpg文件直接修改后缀名为png):

它的源码,有兴趣可以研究一下:



function readUInt32(buffer, offset, bigEndian) {

    if (buffer.readUInt32) {

        return buffer.readUInt32(offset, bigEndian);

    }

    var value;     if (bigEndian) {         if (buffer.readUInt32BE) {             return buffer.readUInt32BE(offset);         }         value = (buffer[offset] << 24) + (buffer[offset+1] << 16) + (buffer[offset+2] << 8) + buffer[offset+3];     }     else {         if (buffer.readUInt32LE) {             return buffer.readUInt32LE(offset);         }         value = buffer[offset] + (buffer[offset+1] << 8) + (buffer[offset+2] << 16) + (buffer[offset+3] << 24);     }     return value; }

function readUInt16(buffer, offset, bigEndian) {     if (buffer.readUInt16) {         return buffer.readUInt16(offset, bigEndian);     }

    var value;     if (bigEndian) {         if (buffer.readUInt16BE) {             return buffer.readUInt16BE(offset);         }         value = (buffer[offset] << 8) + buffer[offset+1];     }     else {         if (buffer.readUInt16LE) {             return buffer.readUInt16LE(offset);         }         value = buffer[offset] + (buffer[offset+1] << 8);     }     return value; }

function readBit(buffer, offset, bitOffset) {     if (bitOffset > 7) {         offset += Math.floor(bitOffset / 8);         bitOffset = bitOffset % 8;     }

    var b = buffer[offset];     if (bitOffset < 7) {         b >>>= (7 - bitOffset);     }

    var val = b & 0x01;     return val; }

function readBits(buffer, offset, bitOffset, bitLen, signed) {     var val = 0;         var neg = false;     if (signed) {         if (readBit(buffer, offset, bitOffset) > 0) {             neg = true;         }         bitLen--;         bitOffset++;     }

    var bytes = [];     for (var i = 0; i < bitLen; i++) {         var b = readBit(buffer, offset, bitOffset + i);         if (i>0 && (bitLen - i) % 8 == 0) {             bytes.push(val);             val = 0;         }         val <<= 1;         val |= b;     }     bytes.push(val);

    val = new Buffer(bytes);     val.negative = neg?true:false;     return val; }

function imageInfoPng(buffer) {     var imageHeader = [0x49, 0x48, 0x44, 0x52],         pos = 12;

    if (!checkSig(buffer, pos, imageHeader)) {         return false;     }

    pos += 4;     return {         type: 'image',         format: 'PNG',         mimeType: 'image/png',         width: readUInt32(buffer, pos, true),         height: readUInt32(buffer, pos+4, true),     }; }

function imageInfoJpg(buffer) {     var pos = 2,         len = buffer.length,         sizeSig = [0xff, [0xc0, 0xc2]];

    while (pos < len) {         if (checkSig(buffer, pos, sizeSig)) {             pos += 5;             return {                 type: 'image',                 format: 'JPG',                 mimeType: 'image/jpeg',                 width: readUInt16(buffer, pos+2, true),                 height: readUInt16(buffer, pos, true),             };         }

        pos += 2;         var size = readUInt16(buffer, pos, true);         pos += size;     } }

function imageInfoGif(buffer) {     var pos = 6;

    return {         type: 'image',         format: 'GIF',         mimeType: 'image/gif',         width: readUInt16(buffer, pos, false),         height: readUInt16(buffer, pos+2, false),     }; }

function imageInfoSwf(buffer) {     var pos = 8,         bitPos = 0,         val;

    if (buffer[0] === 0x43) {         try {             // If you have zlib available ( npm install zlib ) then we can read compressed flash files             buffer = require('zlib').inflate(buffer.slice(8, 100));             pos = 0;         }         catch (ex) {             // Can't get width/height of compressed flash files... yet (need zlib)             return {                 type: 'flash',                 format: 'SWF',                 mimeType: 'application/x-shockwave-flash',                 width: null,                 height: null,             }         }     }

    var numBits = readBits(buffer, pos, bitPos, 5)[0];     bitPos += 5;         val = readBits(buffer, pos, bitPos, numBits, true);     var xMin = (numBits > 9 ? readUInt16(val, 0, true) : val[0]) * (val.negative ? -1 : 1);     bitPos += numBits;

    val = readBits(buffer, pos, bitPos, numBits, true);     var xMax = (numBits > 9 ? readUInt16(val, 0, true) : val[0]) * (val.negative ? -1 : 1);     bitPos += numBits;

    val = readBits(buffer, pos, bitPos, numBits, true);     var yMin = (numBits > 9 ? readUInt16(val, 0, true) : val[0]) * (val.negative ? -1 : 1);     bitPos += numBits;

    val = readBits(buffer, pos, bitPos, numBits, true);     var yMax = (numBits > 9 ? readUInt16(val, 0, true) : val[0]) * (val.negative ? -1 : 1);

    return {         type: 'flash',         format: 'SWF',         mimeType: 'application/x-shockwave-flash',         width: Math.ceil((xMax - xMin) / 20),         height: Math.ceil((yMax - yMin) / 20),     }; }

function checkSig(buffer, offset, sig) {     var len = sig.length;     for (var i = 0; i < len; i++) {         var b = buffer[i+offset],             s = sig[i],             m = false;

        if ('number' == typeof s) {             m = s === b;         }         else {             for (var k in s) {                 var o = s[k];                 if (o === b) {                     m = true;                 }             }         }

        if (!m) {             return false;         }     }

    return true; }

module.exports = function imageInfo(buffer, path) {     var pngSig = [0x89, 0x50, 0x4e, 0x47, 0x0d, 0x0a, 0x1a, 0x0a];     var jpgSig = [0xff, 0xd8, 0xff];     var gifSig = [0x47, 0x49, 0x46, 0x38, [0x37, 0x39], 0x61];     var swfSig = [[0x46, 0x43], 0x57, 0x53];

    if (checkSig(buffer, 0, pngSig)) return imageInfoPng(buffer);     if (checkSig(buffer, 0, jpgSig)) return imageInfoJpg(buffer);     if (checkSig(buffer, 0, gifSig)) return imageInfoGif(buffer);     if (checkSig(buffer, 0, swfSig)) return imageInfoSwf(buffer);

    return false; };

 类似资料:
  • 问题内容: 如何获得泛型的“真实”类? 例如: 如果T =整数 输出: 如果T =字符串 输出: 谢谢 问题答案: 如果您的类中有一个实例类型T的实例变量,并且碰巧已设置好该变量,则可以打印该变量的类。

  • 问题内容: 我需要在node.js的帮助下获取文件的文件类型以设置内容类型。我知道我可以很容易地检查文件的扩展名,但我也得到了一个没有扩展名的文件应有的内容类型,麻生太郎。 这是我的代码(我知道这没有多大意义,但这是我需要的基础): 我还没有在API中找到该函数,因此如果有人可以告诉我该怎么做,我会很高兴。 问题答案: 看一下mmmagic模块。它是一个libmagic绑定,似乎可以完全满足您的要

  • 问题内容: 我正在使用反射包来获取任意数组的类型,但是 如何从数组中获取类型?我知道如何从价值中获取价值。 http://play.golang.org/p/sNw8aL0a5f 问题答案: 更改: 至: 顺便说一句,不是一个数组而是一个整数 切片 。

  • 本文向大家介绍解决Android从相册中获取图片出错图片却无法裁剪问题的方法,包括了解决Android从相册中获取图片出错图片却无法裁剪问题的方法的使用技巧和注意事项,需要的朋友参考一下 在学习获取相册中图片进行裁剪的时候遇到了比较大的问题,在纠结了近半天才真的解决,下面分享一下学习经验。 问题: 选择了相册中的图片之后要进入图片裁剪的时候出错,(华为)手机提示“此图片无法获取”,经百度后,明白是

  • 本文向大家介绍canvas怎么解决图片和文字模糊的问题?相关面试题,主要包含被问及canvas怎么解决图片和文字模糊的问题?时的应答技巧和注意事项,需要的朋友参考一下 模糊问题的根源是dpr的不同导致 解决思路: canvas视图尺寸相同的情况下,canvas画布放大dpr倍,最终画出来的图片相当于缩小了dpr倍,然后通过ctx.scale(dpr,dpr)还原大小

  • 本文向大家介绍PHP获取用户客户端真实IP的解决方案,包括了PHP获取用户客户端真实IP的解决方案的使用技巧和注意事项,需要的朋友参考一下 获取客户端ip其实不是个简单的活儿,因为存在Ip欺骗,和代理问题,所以获取客户端的IP的真实性会打折扣的,不能百分百准确.但是我们还是尽量找一个比较完善的获取客户端真正ip方法.使用php获取IP的方法能找到很多. 现在需要对这段代码进行解释,这里用到了两个函