<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        node.js解決獲取圖片真實文件類型的問題_node.js

        來源:懂視網 責編:小采 時間:2020-11-27 21:30:41
        文檔

        node.js解決獲取圖片真實文件類型的問題_node.js

        node.js解決獲取圖片真實文件類型的問題_node.js:遇到一個需求:假定有一個圖片文件,真實的類型為jpg,而有人偷懶把jpg直接復制一張,存為同名的png文件,這樣在as3讀取文件時不會遇到問題,但手機c++在讀取文件時卻遇到問題了 - -! 現在就需要寫一個程序,遍歷所有文件夾下的文件,查找文件格式不正常
        推薦度:
        導讀node.js解決獲取圖片真實文件類型的問題_node.js:遇到一個需求:假定有一個圖片文件,真實的類型為jpg,而有人偷懶把jpg直接復制一張,存為同名的png文件,這樣在as3讀取文件時不會遇到問題,但手機c++在讀取文件時卻遇到問題了 - -! 現在就需要寫一個程序,遍歷所有文件夾下的文件,查找文件格式不正常
        遇到一個需求:假定有一個圖片文件,真實的類型為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;
        };

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        node.js解決獲取圖片真實文件類型的問題_node.js

        node.js解決獲取圖片真實文件類型的問題_node.js:遇到一個需求:假定有一個圖片文件,真實的類型為jpg,而有人偷懶把jpg直接復制一張,存為同名的png文件,這樣在as3讀取文件時不會遇到問題,但手機c++在讀取文件時卻遇到問題了 - -! 現在就需要寫一個程序,遍歷所有文件夾下的文件,查找文件格式不正常
        推薦度:
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 亚洲人成依人成综合网| 国产免费观看网站| 亚洲日韩精品射精日| 一级毛片免费不卡| 亚洲五月午夜免费在线视频| 成人午夜影视全部免费看| 波多野结衣免费视频观看| 老司机午夜精品视频在线观看免费 | 免费欧洲美女牲交视频| 久久亚洲AV成人无码国产最大| 国产一级淫片免费播放电影 | 精品一区二区三区免费毛片| 国产在线观看www鲁啊鲁免费| 人成午夜免费大片在线观看| 中文亚洲AV片在线观看不卡| 国产精品免费高清在线观看| 亚洲国产人成网站在线电影动漫| 午夜性色一区二区三区免费不卡视频| 亚洲一区二区三区在线网站| 永久黄网站色视频免费观看| 一区二区三区免费视频观看| 亚洲爆乳无码专区| 国产四虎免费精品视频| 亚洲人成未满十八禁网站| 免费一看一级毛片| 国产羞羞的视频在线观看免费| 亚洲精品中文字幕麻豆| 日韩精品无码人妻免费视频| 精品一区二区三区高清免费观看| 亚洲网址在线观看| 国产精品国产免费无码专区不卡 | 亚洲天堂2017无码中文| 亚洲视频在线精品| 1区2区3区产品乱码免费| 亚洲精品无码高潮喷水A片软| 精品国产日韩亚洲一区| 青青视频观看免费99| 乱爱性全过程免费视频| 久久综合亚洲色HEZYO社区| 国产精品麻豆免费版| 免费无码又爽又刺激高潮视频|