nodejs實現本地上傳圖片並預覽功能(express4.0+)


Express為:4.13.1  multyparty: 4.1.2

代碼主要實現本地圖片上傳到nodejs服務器的文件下,通過取圖片路徑進行圖片預覽

寫在前面:計划實現圖片上傳預覽功能,但是本地圖片上傳所獲得路徑為 C:\fakepath\"+文件名的形式,得不到文件真實路徑,所以無法直接預覽,於是采用將圖片上傳至服務器,傳回服務器路徑,實現預覽。前端采用通過ajax方式上傳文件,使用FormData進行ajax請求  ,nodejs端采用multiparty模塊

相關查看文檔:

通過Ajax方式上傳文件,使用FormData進行Ajax請求

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>
html

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);
                }
            });    
        }
    });
js

 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');
    }
  });
}
users.js

部分說明:

文件上傳至服務器后 路徑path變為:public\files\images\W-jy9YsxsPjNpQHslzGvdXBk.jpg

由於在app.js中設置過public為默認路徑,所以整理地址時需要去掉public,並且把‘\’變成‘/’

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

 

 最后效果大概是這樣的,html部分不一樣~我的是jade模板,還有css什么的,並木有列出來

點擊空白處,上傳圖片,接下來的功能就是點擊上傳把地址放到數據庫里~(這個功能還木有做呢)

 

 

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM