保藏本站 保藏本站
188bet注册网主页 - 软件测验 - 常用手册 - 站长东西 - 技能社区
主页 > JavaScript > nodejs > 正文

主页 - PHP - 数据库 - 操作体系 - 游戏开发 - JS - Android - MySql - Redis - MongoDB - Win8 - Shell编程 - DOS指令 - jQuery - CSS款式 - Python - Perl

Access - Oracle - DB2 - SQLServer - MsSql2008 - MsSql2005 - Sqlite - PostgreSQL - node.js - extjs - JavaScript vbs - Powershell - Ruby

Express系列之multer上传的运用

这两天在看《nodejs威望攻略》,这本书看了好久了,可是读的一向不细,这次才好好看了一遍。

收成仍是蛮多的,首要在于wenpack运用的一些细节问题,有点茅塞彻悟的体会吧,另外在node上也不再一脸懵逼了。不过说实话,以现在的水平向直接运用node做点什么仍是挺难的,今日测验了下链接mongodb和mysql数据库,虽然能运用,但仍是怪怪的。所以就想先运用现有的结构,再反推学习node。

结构的话就选了这个express.

首要便是测验了几个书里说到的中间件,书写的有些早,许多api都过期了,照着官网一点一点找更新的当地看。

现在觉得对我有用的是:multer和static。

后者能够在本地调试页面,关于手机页面特别有用。

这次首要说一下multer,我并没有完成一切的功用,仅仅完成单图片上传这一个功用,其他的再探索喽。

检查图片

这是文件的整个目录,首要就两个,一个是根目录下的main.js,还有一个是public/index.html。

放代码:

//main.js
let express = require('express');

var multer = require('multer')

var storage = multer.diskStorage({
  destination: function (req, file, cb) {
   cb(null, 'public/');
  },
  filename: function (req, file, cb) {
   cb(null, Date.now() + '.png');
  }
 })
 
var upload = multer({ storage: storage })

//var upload = multer({ dest: 'public/' })
 

let app = express()

app.use(express.static('public'))

app.post('/public/index.html',upload.single('myfile'),(req,res,next)=>{
  console.log(req.file)
  res.send(req.file)
})

app.listen(3300,'127.0.0.1')

<!-- index.html -->

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Document</title>
</head>

<body>
  <input type="file" id="file" accept="image/*">
  <div id="result"></div>
  <img src="" alt="" id="img" width="40" height="40">
  <script>
    let file = document.getElementById('file');
    file.onchange = function (e) {
      let file = e.target.files[0];
      let xhr = new XMLHttpRequest();
      let fd = new FormData();
      fd.append('myfile', file)
      xhr.open('post', '/public/index.html')
      xhr.onload = function () {
        // console.log(xhr)
        if (xhr.status === 200) {
          let data = JSON.parse(xhr.responseText)
          document.getElementById('result').innerHTML = this.response
          document.getElementById('img').src = data.filename
        }
      }
      xhr.send(fd)
    }
  </script>
</body>

</html>

不想引证jquery库,我就原生写的ajax,总的来说应该没什么难的,总归便是点击按钮挑选完图片之后,会将图片的信息放在一个键名为myfile的目标中,传给后台。

express把接受到的图片存储在/public/文件下,这儿有个小小的坑。能够看到我在main.js注释了这样一行代码:

var upload = multer({ dest: 'public/' })

其实最开端的时分我用的便是这一行代码,dest的意思是挑选一个途径去存储文件,可是这样写有一个小小的问题,存入进来的文件是没有后缀名的。

我在向前台回来数据的时分

res.send(req.file)

这个问题就很严峻,比方一个场景是我上传一张图片做头像,可是等我下次进入自己的个人页面,后台给我回来的数据没有办法作为图片的地址运用,这就很麻烦了。所以在网上找了一个原因,就把上面的代码注释换成了这个:

var storage = multer.diskStorage({
  destination: function (req, file, cb) {
   cb(null, 'public/');
  },
  filename: function (req, file, cb) {
   cb(null, Date.now() + '.png');
  }
})

var upload = multer({ storage: storage })

destination是文件存储的地址,filename设置的是文件的姓名,那在这儿假如写成这种:

filename: function (req, file, cb) {
 cb(null, file.fieldname + '.png');
}

你会发现你传入的每一张图片的姓名都是myfile.png,新的掩盖旧的。所以为了能保存传入的一切图片,我就运用Date.now()作为每张图片不同的辨认符,这样就不会再呈现掩盖的状况。

现在就这样,下次弄出来了多图片上传我再接着更新。

以上便是本文的全部内容,期望对我们的学习有所协助,也期望我们多多支撑188bet注册网。

Mac 装置 nodejs办法(图文具体过程)
这几日因为需求需求又暂时用到nodejs,之前装置过好几回,可是每次仍是不由得百度下,所以这次在此mark下Mac下nodejs的装置和查验,给自己留个符号,

Node.js学习教程之HTTP/2服务器推送【译】
前语最近Node.jsv8.4+版别发布带来了体会版的HTTP/2,你能够自己经过设置参数--expose-http2发动。这篇文章,我将介绍HTTP/2最重要的一方面服务器推送而且创

运用nvm办理不同版别的node与npm的办法
本文介绍了运用nvm办理不同版别的node与npm,共享给我们,具体如下:弥补阐明:Mac下经过brewinstallnvm所装置的nvm,因为装置途径不同,无法正确启用。

本周排行

更新排行

强悍的草根IT技能社区,这儿应该有您想要的! 友情链接:b2b电子商务
Copyright © 2010 touzhuwang75.com. All Rights Rreserved  京ICP备05050695号