node.js实现图片上传(包含缩略图)

图片上传

使用multiparty插件实现上传

安装multiparty

npm i --save multiparty

代码实现

const multiparty = require(‘multiparty‘);
let form = new multiparty.Form({uploadDir: upload.path});
构造参数说明
  • encoding 设置接收数据编码,默认是utf-8
  • maxFieldsSize 限制字段可以分配的内存量,默认2M
  • maxFields 限制在发出错误事件之前将要解析的字段数,默认1000
  • maxFilesSize 限制总文件大小,默认无穷大
  • autoFields 启用字段事件并禁用字段的部分事件。如果添加字段侦听器,则自动将其设置为true。
  • autoFiles 启用文件事件并禁用文件的部分事件。如果添加了一个文件侦听器,则自动将其设置为true。
  • uploadDir 文件上传的目录

==如果回调提供,autofields和autofiles被设置为true,所有字段和文件的收集和传递给回调,不再需要听任何形式的事件。==

事件说明
  • part 请求文件数据时触发,回调函数是一个实现可读流的实例对象

    • headers:头部文件
    • name:字段名称
    • filename:文件名称
    • byteFffset:主体数据的字节偏移量
    • byteCount:数据总的字节长度
  • aborted 在请求中止时触发
  • close 在请求结束之后触发
  • file 接收到文件的参数
    • name:字段名称
    • file:存储着文件信息的对象
    • fieldName:字段名称
    • originalFilename:文件名称
    • path:写到磁盘上文件的具体路径
    • headers:存储着头部信息
    • size:文件具体大小
  • field 获取请求的具体数据。回调函数两个参数
    • name:字段名
    • value:字段值

==注意使用part事件时,如果同时监听fields和files事,part事件会获取不到数据。==

更多说明

增加事件监听后

    let upload = uploadPath();
    console.dir(upload);
    let form = new multiparty.Form({
        uploadDir: upload.path
    });
    form.on(‘error‘, function (err) {
        console.log(‘Error parsing form: ‘ + err.stack);
    });
    form.on(‘file‘, (name, file) => {
        console.log(file);
        res.json(file);
    });
    form.on(‘close‘, function () {
        console.log(‘Upload completed!‘);
    });
    form.parse(req);

图片处理

一般来说上传图片都会进行简单的处理,例如无损画质压缩,缩略图生成等

1、用 resize-img 进行缩略图制作

安装组件

npm install --save resize-img

代码实现
    const resizeImg = require(‘resize-img‘);

    resizeImg(fs.readFileSync(file_path), {width: 800}).then(buf => {
        fs.writeFileSync(file_path, buf);
    });

2、使用python图片处理库PIL

为什么使用python?

CPU密集型任务是Node.js的软肋,当服务器同时执行多个图片处理时(特别是比较大的图片时),会出现BUG,所以我们可以选用python图片处理库PIL

PIL安装
pip install pillow
python实现
from PIL import Image
import glob
import os
import sys

try:
    im = Image.open(sys.argv[1])
    o_width = im.size[0]
    o_height = im.size[1]
    thumb_width = 400
    size = (thumb_width, o_height * thumb_width / o_width)
    im.thumbnail(size)
    im.save(sys.argv[2],im.format)
    print(sys.argv[2])
except IOError:
     print("cannot create thumbnail for", sys.argv[1])
node调用pyhton
const path = require(‘path‘);
const exec = require(‘child_process‘).exec;

let baseDir = path.resolve(__dirname, ‘..‘);

let thumb_pic = (arg1, arg2) => {
    return new Promise((resolve, reject) => {
        let py_path = baseDir + "/public/py/";
        exec(`python ${py_path}thumb_pic.py  ${arg1} ${arg2}`, function (error, stdout, stderr) {
            if (stdout.length > 0) {
                console.log(‘you offer args:‘, stdout);
                resolve(true);
            } else {
                console.log(‘you don\‘t offer args‘);
                resolve(false);
            }
            if (error) {
                console.info(‘stderr : ‘ + stderr);
                reject(stderr);
            }
        });
    });
};

module.exports.thumb_pic = thumb_pic;

这里我推荐使用第二种方法

源码地址

原文地址:https://www.cnblogs.com/youjun1991/p/8664171.html

时间: 2024-10-09 13:56:58

node.js实现图片上传(包含缩略图)的相关文章

Nodejs学习笔记(八)--- Node.js + Express 实现上传文件功能(felixge/node-formidable)

目录 前言 formidable简介 创建项目并安装formidable 实现上传功能 运行结果 部分疑惑解析 写在之后 前言 前面讲了一个构建网站的示例,这次在此基础上再说说web的常规功能----文件上传,示例以一个上传图片的功能为例子 上传功能命名用formidable实现,示例很简单! PS:最近比较忙,距上一次更新已经比较久了^_^! formidable简介 nodejs原生实现上传还是比较麻烦,有兴趣的自已去参考一下网上有网友写的代码 这里选择了formidable,也是githu

JS实现图片上传预览效果:方法一

<script type="text/javascript"> //处理file input加载的图片文件 $(document).ready(function(e) { //判断浏览器是否有FileReader接口 if(typeof FileReader =='undefined') { /*$("#images_show").css({'background':'none'}).html('亲,您的浏览器还不支持HTML5的FileReader接口

纯js实现图片上传

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml" ><head><title>本地图片预览</title><

html + js 实现图片上传,压缩,预览及图片压缩后得到Blob对象继续上传问题

先上效果 上传图片后(设置了最多上传3张图片,三张后上传按钮消失) 点击图片放大,可以使用删除和旋转按钮 (旋转功能主要是因为ios手机拍照后上传会有写图片被自动旋转,通过旋转功能可以调正) html页面 需要引入weui.min.css 不然没法渲染样式, 将下面的代码放在需要上传文件的地方就行了,如果不需要图片旋转功能, 可以直接删掉那个div, 改不改js无影响 addPhoto.html <!--图片缩略图--> <div class="weui-cells weui-

js实现图片上传及预览----------------------&gt;&gt;兼容ie6-8 火狐以及谷歌

<head runat="server"> <title>图片上传及预览(兼容ie6/7/8 firefox/chrome)</title> <script src="../Scripts/jquery-1.4.2.min.js" type="text/javascript"></script> </head> <body> <form id="f

js实现图片上传预览原理

现在网上有很多成熟的图片上传的插件,由于之前对于图片上传未接触过,不了解其实现原理.网上查阅了相关资料,了解到其是基于FileReader Api. 众所周知,大家平时做兼容性都是为了兼容低版本浏览器,图片上传则恰恰相反.基于浏览器的安全策略,file标签在现代浏览器中已经获取不到真实路径.恰恰相反,低版本ie却能获取到真实物理路径.所以此功能是基于现代浏览器的解决方案. FileReader就是html5为我们提供的读取文件的api.它的作用就是把文本流按指定格式读取到缓存,以供js调用. F

node.js使用multiparty上传文件

multiparty使用:multiparty文档 https://www.npmjs.com/package/multiparty 下面介绍一下利用formData向后台提交图片的过程:写在前面的话: 1.实例中前端使用的是vue.js,不过并不影响上传思路.2.后台通过multiparty来解析formData step1:先来看一看前端上传部分的代码: 这是我写的一个上传图片的组件,这里并没有进行图片压缩处理(我们可以用canvas来进行图片压缩,自行搜索下即可). 这一段其实也很好理解,

js实现图片上传预览功能,使用base64编码来实现

实现图片上传的方法有很多,这里我们介绍比较简单的一种,使用base64对图片信息进行编码,然后直接将图片的base64信息存到数据库. 但是对于系统中需要上传的图片较多时并不建议采用这种方式,我们一般会选择存图片路径的方式,这样有助于减小数据库压力,base64 编码后的图片信息是一个很长的字符串,一般我们使用longText类型来将其存入数据库. html代码如下: <div class="col-sm-6"> <img id="headPortraitI

js实现图片上传本地预览

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" > <head> <meta http-equiv="Content