node+express+jquery 单图和多图上传

最近开发了一个小的页面,单图和多图上传。node+express搭建本地服务器,采用Jquery编写传统的逻辑代码。

核心代码:

app.js

var fs = require('fs')

var multer = require('multer')

var express = require('express')

var path = require('path')

var router = express.Router()


let storage = multer.diskStorage({

  destination: function(req, file, cb) {

    // 文件初始路径

    const date = new Date();

    const toPad2 = num => num.padStart(2, '0');

    const filePath = `./public/uploadimg/${date.getFullYear()}${toPad2(`${date.getMonth() + 1}`)}${toPad2(

      `${date.getDate()}`)}_images`;

    if (!fs.existsSync(filePath)) {

      fs.mkdir(filePath, err => {

        if (err) {

          console.log(err)

        } else {

          cb(null, filePath)

        }

      })

    } else {

      cb(null, filePath)

    }

  },

  filename: function(req, file, cb) {

    var ext = path.extname(file.originalname)

    // UUID 处理

    function guid() {

      return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function(

        c

      ) {

        var r = (Math.random() * 16) | 0,

          v = c == 'x' ? r : (r & 0x3) | 0x8

        return v.toString(16)

      })

    }

    cb(null, file.fieldname + guid() + Date.now() + ext)

  }

})

var upload = multer({ storage: storage })

//单文件上传

router.post('/upload1', upload.single('file'), function(req, res, next) {

  const date = new Date();

  const toPad2 = num => num.padStart(2, '0');

  const imgDir = `${date.getFullYear()}${toPad2(`${date.getMonth() + 1}`)}${toPad2(

      `${date.getDate()}`)}_images/`;

  res.json({

    code: 200,

    filePath:

      'http://' +

      req.headers.host +

      '/uploadimg/' + imgDir +

      path.basename(req.file.path)

  })

})

//多文件上传

router.post("/upload2",upload.array("file",20),function(req,res,next){  

  const date = new Date();

  const toPad2 = num => num.padStart(2, '0');

  const imgDir = `${date.getFullYear()}${toPad2(`${date.getMonth() + 1}`)}${toPad2(

      `${date.getDate()}`)}_images/`;

  var filePath=[];

  for(var i=0; i<req.files.length;i++){

    var tmpPath = 'http://' +

     req.headers.host +

     '/uploadimg/' + imgDir +

     path.basename(req.files[i].path);

     filePath.push(tmpPath);

  }

  res.json({

    code:200,

    filePath:filePath

  })

})

//提交

router.post('/submmit', function(req, res) {

  console.log(req)

  var data={

    "similarList":[

      {

        "cutImgPath":"img/1.jpg",

        "picName":"ddd",

        "segNum":"",

        "similarValue":"80%"

      },

      {

        "cutImgPath":"img/2.jpg",

        "picName":"ddd",

        "segNum":"",

        "similarValue":"60%"

      }

    ]

  }

  res.json({ code: 200, data: data })

})

module.exports = router


html

<!DOCTYPE html>

<html lang="zh-cmn-Hans">

  <head>

    <title>图片对比识别</title>

    <link  type="text/css" rel="stylesheet"  href="./stylesheets/bootstrap.min.css" />

    <link  type="text/css" rel="stylesheet" href="./stylesheets/bootstrap-theme.min.css" />

    <link type="text/css" rel="stylesheet" href="./stylesheets/style.css" />

  </head>

  <body>

    <div class="container">

      <div class="info">图片对比识别平台</div>

      <form

        class="form-horizontal"

        enctype="multipart/form-data"

        method="post"

        action="javascript:;"

        role="form"

        id="frmUploadFile"

      >

      <!-- 单图片 -->

        <div class="g-m-20">

          <p class="g-ta-l">原图片:</p>

          <input type="file" name="files" class="form-control" id="fileupload1"/>

          <button class="btn btn-default" onClick="uploadImage(0)">

            确认上传

          </button>

        </div>

      <!-- 多图片 -->

        <div class="g-m-20">

          <p class="g-ta-l">对比图片:</p>

          <input type="file" name="filesmore" class="form-control" id="fileupload2"  multiple="multiple"/>

          <button class="btn btn-default" onClick="uploadImage(1)">

            确认上传

          </button>

          <ul class="list-group" id="uploadarea"></ul>

        </div>

        <div class="g-m-20">

          <button class="btn btn-primary submmit" onClick="submmit()">

            开始识别

          </button>

        </div>       

      </form>

      <div class="list-wrapper">

        <p class="bold">图片识别结果</p>

        <ul class="title">

          <li class="left">信息要素</li>

          <li class="right">识别结果</li>

        </ul>

        <ul class="content">

          <li class="no-data">暂无结果</li>

        </ul>

      </div>

    </div>

    <script src="./javascripts/jquery.min.js"></script>

<script>

  //获取配置文件

      var types;

      var filePath1;

      var filePath2;


/******************文件上传*************************************/

      function uploadImage(index) {

        var oneOrMore = index;

        var headPhotoFile;

        if(oneOrMore=='0'){

          headPhotoFile=$("#fileupload1");

        }else{

          headPhotoFile=$("#fileupload2");

        }


        if (headPhotoFile[0].files.length == 0) {

          alert('请上传影像');

          return

        }

        if(!/\.(gif|jpg|jpeg|png|GIF|JPG|PNG)$/.test(headPhotoFile.val())){

            alert("图片类型必须是gif,jpeg,jpg,png中的一种");

            return;

        }

        var url="";

        if(index=='0'){//说明是原文件上传

          var file = $("#fileupload1");

          var formData = new FormData();

          formData.append('file',file[0].files[0]);

          url = "/upload1";

          console.log(formData);

          // var formData = new FormData($('#fileupload1')[0])

        }else{//说明是对比图上传

          var file = $("#fileupload2");

          var formData = new FormData();

          for(var i=0;i<file[0].files.length;i++){//这里如果单张上传就不必遍历直接formData.append('file',file.files[0])

                  formData.append('file',file[0].files[i]);

          }

          console.log(formData);

          url = "/upload2";

        }


        $.ajax({

          url: url,

          type: 'post',

          data: formData,

          async: false,

          cache: false,

          contentType: false,

          processData: false,

          success: function(data) {

            if (200 === data.code) {

              if (data.filePath) {

                if(oneOrMore=='0'){

                  filePath1 = data.filePath;

                }else{

                  filePath2 = data.filePath;

                }

                alert("上传成功");

                $('.submmit').attr('disabled', false)

              }

            } else {

              alert('上传失败')

            }

          },

          error: function(err) {

            console.log('err', err)

            alert('影像上传服务通信发生错误')

          }

        })

      }

      function submmit() {

        if ($('#fileupload1')[0].files.length == 0 || $('#fileupload2')[0].files.length == 0) {

          alert('请先上传影像')

          return

        }

        //获取当前影像类型

        var index = $('input:radio[name="filetype"]:checked').attr('id');

        var id = Math.random(1,100);

        $.ajax({

          url: '/submmit',

          type: 'post',

          data: {img: filePath1,multImgData:filePath2,uuid:id },

          async: false,

          success: function(data) {

            if (200 === data.code) {

              alert('识别成功')

              //数据处理

              console.log(data);     

      }

              $('.content').html(_html);

              $('.submmit').attr('disabled', true)

            }

          },

          error: function(err) {}

        })

      }

    $('input').on('change', function(event) {

        var files = event.target.files,

          reader = new FileReader()

        if (files && files[0]) {

          reader.onload = function(ev) {

            // $('img').attr('src', ev.target.result);

          }

          reader.readAsDataURL(files[0])

        }

      })

    </script>

  </body>

</html>

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,236评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,867评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,715评论 0 340
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,899评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,895评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,733评论 1 283
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,085评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,722评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,025评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,696评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,816评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,447评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,057评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,009评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,254评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,204评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,561评论 2 343

推荐阅读更多精彩内容