国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

使用express+multer實現node中的圖片上傳功能

2019-11-19 14:25:45
字體:
來源:轉載
供稿:網友

下文給大家介紹使用express+multer實現node中的圖片上傳功能,具體內容介紹如下所示:

在前端中,我們使用ajax來異步上傳圖片,使用file-input來上傳圖片,使用formdata對象來處理圖片數據,post到服務器中

在node中使用multer中間件來對上傳路由接口進行處理

multer文檔

package.json

html部分

<body><div class="form-group">    <label>File input:</label>    <input type="file" name="file" id="file">    <p id="result"></p>    <img id="img" src="">  </div>  <button id="upload" class="btn btn-default">提交</button>  </body>

js部分

<script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script>  <script>    //上傳圖片的業務邏輯函數    function uploadFile(){      //上傳圖片的input      var file = document.getElementById("file")      //因為準備用post提交,又因為圖片的內容比較大,所以我們選擇使用formdata來承載數據      //創建formdata對象      var formData = new FormData();      //給formdata對象中放入數據(鍵值對的方式)      formData.append('file',file.files[0]);      //提交請求      $.ajax({        url: '/upload',//請求路徑        type: 'POST',        data: formData,        contentType: false,//為了讓瀏覽器根據傳入的formdata來判斷contentType        processData: false,//同上        success: function(data){          if(200 === data.code) {            $('#result').html("上傳成功!");            $('#img').attr('src',data.data);          } else {            $('#result').html("上傳失敗!");          }          console.log(2)        },        error: function(){          $("#result").html("與服務器通信發生錯誤");        }      });      console.log(1)    }    //給按鈕添加點擊事件    function postPage() {        //上傳按鈕        var uploada = document.getElementById('upload');        uploada.addEventListener("click",function () {          uploadFile();        },false);    }    window.onload = function () {      postPage();    }</script>

NodeJS邏輯代碼

const http = require('http')const path = require('path')const express = require('express')//是nodejs中處理multipart/form-data數據格式(主要用在上傳功能中)的中間件//文檔:https://github.com/expressjs/multer/blob/master/doc/README-zh-cn.mdconst multer = require('multer')const app = express()//配置express的靜態目錄app.use(express.static(path.join(__dirname, 'public')));app.get('/',(req,res)=>{  res.sendFile(__dirname+'/index.html')})//配置diskStorage來控制文件存儲的位置以及文件名字等var storage = multer.diskStorage({  //確定圖片存儲的位置  destination: function (req, file, cb){    cb(null, './public/uploadImgs')  },![](http://images2017.cnblogs.com/blog/1283058/201802/1283058-20180201154342296-515041615.png)  //確定圖片存儲時的名字,注意,如果使用原名,可能會造成再次上傳同一張圖片的時候的沖突  filename: function (req, file, cb){    cb(null, Date.now()+file.originalname)  }});//生成的專門處理上傳的一個工具,可以傳入storage、limits等配置var upload = multer({storage: storage});//接收上傳圖片請求的接口app.post('/upload', upload.single('file'), function (req, res, next) {  //圖片已經被放入到服務器里,且req也已經被upload中間件給處理好了(加上了file等信息)  //線上的也就是服務器中的圖片的絕對地址  var url = '/uploadImgs/' + req.file.filename  res.json({    code : 200,    data : url  })});http.createServer(app).listen(3000,()=>{  console.log('server is listening')})

自我感覺良好,不知道博客園為什么要給我移除首頁....

再發一次,if(delete){alert('Never publish anything again.')}else{alert(1)}

總結

以上所述是小編給大家介紹的使用express+multer實現node中的圖片上傳功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 遂川县| 西乌珠穆沁旗| 清水河县| 石首市| 中山市| 津南区| 凉城县| 长春市| 丹阳市| 泽普县| 老河口市| 西乌珠穆沁旗| 且末县| 柳河县| 德惠市| 三都| 唐海县| 油尖旺区| 鸡西市| 沂南县| 泸州市| 拉萨市| 塘沽区| 永胜县| 佛冈县| 清水河县| 武陟县| 西丰县| 乌海市| 勐海县| 贺兰县| 绥江县| 仁化县| 温宿县| 陇西县| 连州市| 秦安县| 大方县| 方城县| 遂平县| 子洲县|