博客项目之图片上传

图片上传

857662-20161126175255596-1532266381.png

html代码
<input type="file" id="file_input" multiple/>

multiple属性可以用来同时上传多张图片

js代码
// 上传图片
function upPic(dom,callback){
  var input = document.getElementById(dom);
  if(typeof FileReader==='undefined'){
      input.setAttribute('disabled','disabled');
  }else{
      input.addEventListener('change',function(){
        var _this = this;
        for(var i=0;i<this.files.length;i++){
            if (!input['value'].match(/.jpg|.gif|.png|.bmp/i)){
                return alert("上传的图片格式不正确,请重新选择")
            }
            var reader = new FileReader();
            reader.readAsDataURL(this.files[i]);
            var fileName = this.files[i].name.substring(this.files[i].name.lastIndexOf('.'));
            (function(fileName){
              reader.onload = function(){
                callback(this,fileName);
              };
            })(fileName);
        }
      },false);
  }
}

upPic('file_input',function(data,fileName){
  $.post('../upfile',{'img':data.result.replace(/^data:image\/\w+;base64,/,""),'fileName':fileName},function(result){
    oTontent.value+= '\n![]('+ result +')\n';
    $('#file_input').val('');
  })
})

监听input的change事件,事件中有一个files属性,里面保存着上传的文件,然后通过FileReader对象里面中的readAsDataURL将图片转换成base64,最后将此数据发送给后端。

后端逻辑
var fs = require('fs');
var qs = require('querystring');

exports.upfile = function(req,res){
  var currentDate = new Date().getTime();
  if(req.url==='/upfile'){
    // 写入图片
    getData(req,function(data,fileName){
      fs.writeFile('./images/articles/' + currentDate + fileName,data,function(err){
        if(err){
          res.send('0');
        }else{
          res.send('./articles/' + currentDate + fileName);
        }
      })
    })
  }
};
// 获取图片
function getData(req,callback){
  var arr = [];
  req.on("data",function(data){
    arr.push(data);
  });
  req.on("end",function(){
    var data = qs.parse(Buffer.concat(arr).toString());
    var img = new Buffer(data.img,'base64');
    callback(img,data.fileName);
  })
}

监听post事件,并且将数据转成对象,通过Buffer对象将数据转成二进制。写入文件后,将当前文件名和路径发送给前端,并显示到文本框中。

857662-20161126180516753-1673181611.png

完。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值