微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

Express为:4.13.1 multyparty: 4.1.2

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

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

相关查看文档:

node-multiparty github

FormData - Web APIs | MDN

部分代码

rush:xhtml;">

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

rush:js;"> $('#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里代码

rush:js;"> app.post('/uploadUserImgPre',routes.users.uploadUserImgPre);

routes/users.js 里代码

rush: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,并且把‘\'变成‘/'

rush:js;"> app.use(express.static(path.join(__dirname,'public')));

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

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐