破解tinypng文件上传的限制

简单破解tinypng文件上传的限制

/** 
 * 帮助文档
 * -------
 * 
 * 获取帮助
 * 指令 -h
 * 
 * 获取命令执行文件夹 
 * 指令 -f 
 * 参数 ./
 * 必填,待处理的图片文件夹
 * 
 * 获取是否深度递归处理图片文件夹
 * 指令 -deep
 * 可选,默认不深度递归
 * 
 * 命令行脚本参考示例
 * > node ./脚本.js -f ./图片文件夹 -deep
 *  */

 const fs = require('fs');
 const path = require('path');
 const https = require('https');
 const URL = require('url').URL;
 const EventEmitter = require('events');
 const err = msg => new EventEmitter().emit('error', msg);
 
 if (getHelp()) return false;
 
 const conf = {
     files: [],
     EntryFolder: getEntryFolder(),
     DeepLoop: getDeepLoop(),
     Exts: ['.jpg', '.png'],
     Max: 5200000, // 5MB == 5242848.754299136
 }
 
 fileFilter(conf.EntryFolder)
 
 console.log("本次执行脚本的配置:", conf);
 console.log("等待处理文件的数量:", conf.files.length)
 
 conf.files.forEach(img => fileUpload(img));
 
  工具函数
 
 /**
  * 获取帮助命令
  * 指令 -h
  */
 function getHelp() {
     let i = process.argv.findIndex(i => i === "-h");
     if (i !== -1) {
       
         return true;
     }
 }
 
 /**
  * 获取命令执行文件夹 
  * 指令 -f 
  * 参数 ./
  * 必填,待处理的图片文件夹
  */
 function getEntryFolder() {
     let i = process.argv.findIndex(i => i === "-f");
     if (i === -1 || !process.argv[i + 1]) return err('获取命令执行文件夹:失败');
     return process.argv[i + 1];
 }
 
 /**
  * 获取是否深度递归处理图片文件夹
  * 指令 -deep
  * 可选,默认不深度递归
  */
 function getDeepLoop() {
     return process.argv.findIndex(i => i === "-deep") !== -1;
 }
 
 /**
  * 过滤待处理文件夹,得到待处理文件列表
  * @param {*} folder 待处理文件夹
  * @param {*} files 待处理文件列表
  */
 function fileFilter(folder) {
     // 读取文件夹
     fs.readdirSync(folder).forEach(file => {
         let fullFilePath = path.join(folder, file)
         // 读取文件信息
         let fileStat = fs.statSync(fullFilePath);
         // 过滤文件安全性/大小限制/后缀名
         if (fileStat.size <= conf.Max && fileStat.isFile() && conf.Exts.includes(path.extname(file))) conf.files.push(fullFilePath);
         // 是都要深度递归处理文件夹
         else if (conf.DeepLoop && fileStat.isDirectory()) fileFilter(fullFilePath);
     });
 }
 
 /**
  * TinyPng 远程压缩 HTTPS 请求的配置生成方法
  */
 
 function getAjaxOptions() {
     return {
         method: 'POST',
         hostname: 'tinypng.com',
         path: '/web/shrink',
         headers: {
             rejectUnauthorized: false,
             "X-Forwarded-For": Array(4).fill(1).map(() => parseInt(Math.random() * 254 + 1)).join('.'),
             'Postman-Token': Date.now(),
             'Cache-Control': 'no-cache',
             'Content-Type': 'application/x-www-form-urlencoded',
             'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/56.0.2924.87 Safari/537.36'
         }
     }
 }
 
 /**
  * TinyPng 远程压缩 HTTPS 请求
  * @param {string} img 待处理的文件
  * @success {
  *              "input": { "size": 887, "type": "image/png" },
  *              "output": { "size": 785, "type": "image/png", "width": 81, "height": 81, "ratio": 0.885, "url": "https://tinypng.com/web/output/7aztz90nq5p9545zch8gjzqg5ubdatd6" }
  *           }
  * @error  {"error": "Bad request", "message" : "Request is invalid"}
  */
 function fileUpload(imgPath) {
     let req = https.request(getAjaxOptions(), (res) => {
         res.on('data', buf => {
             let obj = JSON.parse(buf.toString());
             if (obj.error) console.log(`压缩失败!\n 当前文件:${imgPath} \n ${obj.message}`);
             else fileUpdate(imgPath, obj);
         });
     });
 
     req.write(fs.readFileSync(imgPath), 'binary');
     req.on('error', e => console.error(`请求错误! \n 当前文件:${imgPath} \n`, e));
     req.end();
 }
 
 // 该方法被循环调用,请求图片数据
 function fileUpdate(entryImgPath, obj) {
     let options = new URL(obj.output.url);
     let req = https.request(options, res => {
         let body = '';
         res.setEncoding('binary');
         res.on('data', (data) => body += data);
         res.on('end', () => {
             fs.writeFile(entryImgPath, body, 'binary', err => {
                 if (err) return console.error(err);
                 let log = "压缩成功"
                 log += `优化比例: ${ (( 1 - obj.output.ratio) * 100).toFixed(2) }%`
                 log += `原始大小: ${ (obj.input.size / 1024).toFixed(2) }KB`
                 log += `压缩大小: ${ (obj.output.size / 1024).toFixed(2) }KB`
                 log += `文件:${entryImgPath}`
                 console.log(log);
             });
         });
     });
     req.on('error', e => console.error(e));
     req.end();
 }
 
 // node ./tinypng.js -f ./static/smp/m/course_task

复制上面的代码,直接在node环境下运行命令: node 脚本.js -f 图片文件夹路径
制作不易,觉得对你有帮助,可以请作者喝杯咖啡。
有不懂可以加作者微信探讨:lfj990319
在这里插入图片描述

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Tinypng for Mac插件是一款方便实用的图片压缩工具,它专门为Mac操作系统开发而成。该插件通过优化图片的色彩和减少图片文件尺寸来实现降低图片质量损失的目的。 首先,Tinypng for Mac插件具有很方便的安装和使用方式。用户只需在Mac电脑上下载并安装该插件,然后在需要压缩的图片上点击鼠标右键,选择“Tinypng for Mac”选项即可开始压缩过程。这种简单的操作方式让用户能够快速上手并进行图片压缩。 其次,Tinypng for Mac插件具有高效的压缩功能。该插件使用先进的压缩算法,能够有效地压缩图片的文件大小,而不会明显降低图片的质量。通过减少文件大小,可以加快图片的加载速度,减少网络传输的时间,提高网页的响应速度。 此外,Tinypng for Mac插件还支持批量压缩功能。用户可以选择多个图片文件,然后一次性对它们进行压缩处理。这种批量压缩功能可节省用户的时间和精力,特别适合需要处理大量图片的用户,如网站设计师、摄影师等。 最后,Tinypng for Mac插件为用户提供了压缩前后的效果预览功能。用户在压缩图片之前,可以通过插件界面直观地查看压缩后的图片效果,确保压缩结果满足自己的需求。 总而言之,Tinypng for Mac插件是一款功能强大、操作简单的图片压缩工具。它能够帮助Mac用户快速压缩图片,提高网页加载速度,节省存储空间,并保持较高的图片质量。无论是个人用户还是专业设计人员,都可以从该插件中受益。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值