详解nodejs实现本地上传图片并预览功能(express4.0+)


Posted in NodeJs onJune 28, 2017

Express为:4.13.1  multyparty: 4.1.2

代码主要实现本地图片上传到nodejs服务器的文件下,通过取图片路径进行图片预览

写在前面:计划实现图片上传预览功能,但是本地图片上传所获得路径为 C:\fakepath\"+文件名的形式,得不到文件真实路径,所以无法直接预览,于是采用将图片上传至服务器,传回服务器路径,实现预览。前端采用通过ajax方式上传文件,使用FormData进行ajax请求  ,nodejs端采用multiparty模块

相关查看文档:

node-multiparty github

FormData - Web APIs | MDN

部分代码:

<form name='picForm' action = "javascript:;"method="post" encype = "multipart/form-data" >
  <input type="file" id="test" id="j_imgfile">
</form>
<div>
  <img src="" id="j_imgPic">
</div>

 js中采用change事件,即当选完图片时就发送ajax请求

$('#j_imgfile').on('change',function(){
    // 判断上传文件类型
    var objFile = $('#j_imgfile').val();
    var objType = objFile.substring(objFile.lastIndexOf(".")).toLowerCase();
    var formData = new FormData(document.forms.namedItem("picForm"));
    console.log(objType);
    if(!(objType == '.jpg'||objType == '.png'))
    {
      alert("请上传jpg、png类型图片");
      return false;
    }else{
      $.ajax({
        type : 'post',
        url : '/uploadUserImgPre',
        data: formData ,
        processData:false,
        async:false,
        cache: false, 
         contentType: false, 
        success:function(re){
          re.imgSrc = re.imgSrc.replace('public','');
          re.imgSrc = re.imgSrc.replace(/\\/g,'\/');
          $('#j_imgPic').attr('src',re.imgSrc);
        },
        error:function(re){
          console.log(re);
        }
      });  
    }
  });

 nodejs app.js里代码

app.post('/uploadUserImgPre',routes.users.uploadUserImgPre);

routes/users.js 里代码

exports.uploadUserImgPre = function(req, res, next) {
 //生成multiparty对象,并配置上传目标路径
 var form = new multiparty.Form({uploadDir: './public/files/images'});
 form.parse(req, function(err, fields, files) {
  var filesTmp = JSON.stringify(files);
 
  if(err){
   console.log('parse error: ' + err);
  } else {
   testJson = eval("(" + filesTmp+ ")"); 
   console.log(testJson.fileField[0].path);
   res.json({imgSrc:testJson.fileField[0].path})
   console.log('rename ok');
  }
 });
}

部分说明:

文件上传至服务器后 路径path变为:public\files\images\W-jy9YsxsPjNpQHslzGvdXBk.jpg

由于在app.js中设置过public为默认路径,所以整理地址时需要去掉public,并且把‘\'变成‘/'

app.use(express.static(path.join(__dirname, 'public')));

 最后效果大概是这样的,html部分不一样~我的是jade模板,还有css什么的,并木有列出来

点击空白处,上传图片,接下来的功能就是点击上传把地址放到数据库里~(这个功能还木有做呢)

详解nodejs实现本地上传图片并预览功能(express4.0+)

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

NodeJs 相关文章推荐
轻松创建nodejs服务器(3):代码模块化
Dec 18 NodeJs
基于nodejs+express(4.x+)实现文件上传功能
Nov 23 NodeJs
nodejs利用ajax实现网页无刷新上传图片实例代码
Jun 06 NodeJs
详解nodejs实现本地上传图片并预览功能(express4.0+)
Jun 28 NodeJs
Nodejs 复制文件/文件夹的方法
Aug 24 NodeJs
浅谈NodeJs之数据库异常处理
Oct 25 NodeJs
nodejs实现范围请求的实现代码
Oct 12 NodeJs
PHPStorm中如何对nodejs项目进行单元测试详解
Feb 28 NodeJs
nodejs中实现修改用户路由功能
May 24 NodeJs
基于NodeJS开发钉钉回调接口实现AES-CBC加解密
Aug 20 NodeJs
NodeJS开发人员常见五个错误理解
Oct 14 NodeJs
NodeJS模块Buffer原理及使用方法解析
Nov 11 NodeJs
NodeJS链接MySql数据库的操作方法
Jun 27 #NodeJs
NodeJS自定义模块写法(详解)
Jun 27 #NodeJs
docker中编译nodejs并使用nginx启动
Jun 23 #NodeJs
NodeJs中express框架的send()方法简介
Jun 20 #NodeJs
深入浅析Nodejs的Http模块
Jun 20 #NodeJs
Nodejs实现多房间简易聊天室功能
Jun 20 #NodeJs
NodeJS 实现手机短信验证模块阿里大于功能
Jun 19 #NodeJs
You might like
基于Discuz security.inc.php代码的深入分析
2013/06/03 PHP
浅析php原型模式
2014/11/25 PHP
php实现插入排序
2015/03/29 PHP
PHP实现登录注册之BootStrap表单功能
2017/09/03 PHP
ThinkPHP3.1.2 使用cli命令行模式运行的方法
2020/04/14 PHP
防止动态加载JavaScript引起的内存泄漏问题
2009/10/08 Javascript
比较详细的关于javascript 解析json的代码
2009/12/16 Javascript
Javascript将string类型转换int类型
2010/12/09 Javascript
JQuery中Bind()事件用法分析
2015/05/05 Javascript
js操作css属性实现div层展开关闭效果的方法
2015/05/11 Javascript
Node.js与Sails ~项目结构与Mvc实现及日志机制
2015/10/14 Javascript
在 Express 中使用模板引擎
2015/12/10 Javascript
基于MVC+EasyUI的web开发框架之使用云打印控件C-Lodop打印页面或套打报关运单信息
2016/08/29 Javascript
jQuery实现聊天对话框
2020/02/08 jQuery
Element Notification通知的实现示例
2020/07/27 Javascript
关于JavaScript数组去重的一些理解汇总
2020/09/10 Javascript
JS实现超级好看的鼠标小尾巴特效
2020/12/01 Javascript
python urllib urlopen()对象方法/代理的补充说明
2017/06/29 Python
使用Python设计一个代码统计工具
2018/04/04 Python
详解python3中tkinter知识点
2018/06/21 Python
对python中的iter()函数与next()函数详解
2018/10/18 Python
使用django-guardian实现django-admin的行级权限控制的方法
2018/10/30 Python
Numpy截取指定范围内的数据方法
2018/11/14 Python
解决Python运行文件出现out of memory框的问题
2018/12/03 Python
Python3.5装饰器典型案例分析
2019/04/30 Python
使用Pyinstaller转换.py文件为.exe可执行程序过程详解
2019/08/06 Python
Django Admin后台模型列表页面如何添加自定义操作按钮
2020/11/11 Python
简单html5代码获取地理位置
2014/03/31 HTML / CSS
实习自我评价怎么写
2013/12/02 职场文书
银行简历自我评价
2014/02/11 职场文书
六五普法规划实施方案
2014/03/21 职场文书
培训班开班仪式主持词
2014/03/28 职场文书
中学生家长评语大全
2014/04/16 职场文书
销售口号大全
2014/06/11 职场文书
志愿者事迹材料
2014/12/26 职场文书
一篇文章弄懂Python关键字、标识符和变量
2021/07/15 Python