<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        使用express+multer實現(xiàn)node中的圖片上傳功能

        來源:懂視網(wǎng) 責編:小采 時間:2020-11-27 22:20:14
        文檔

        使用express+multer實現(xiàn)node中的圖片上傳功能

        使用express+multer實現(xiàn)node中的圖片上傳功能:下文給大家介紹使用express+multer實現(xiàn)node中的圖片上傳功能,具體內(nèi)容介紹如下所示: 在前端中,我們使用ajax來異步上傳圖片,使用file-input來上傳圖片,使用formdata對象來處理圖片數(shù)據(jù),post到服務(wù)器中 在node中使用multer中間件來對上傳路由接
        推薦度:
        導讀使用express+multer實現(xiàn)node中的圖片上傳功能:下文給大家介紹使用express+multer實現(xiàn)node中的圖片上傳功能,具體內(nèi)容介紹如下所示: 在前端中,我們使用ajax來異步上傳圖片,使用file-input來上傳圖片,使用formdata對象來處理圖片數(shù)據(jù),post到服務(wù)器中 在node中使用multer中間件來對上傳路由接

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

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

        在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>
         //上傳圖片的業(yè)務(wù)邏輯函數(shù)
         function uploadFile(){
         //上傳圖片的input
         var file = document.getElementById("file")
         //因為準備用post提交,又因為圖片的內(nèi)容比較大,所以我們選擇使用formdata來承載數(shù)據(jù)
         //創(chuàng)建formdata對象
         var formData = new FormData();
         //給formdata對象中放入數(shù)據(jù)(鍵值對的方式)
         formData.append('file',file.files[0]);
         //提交請求
         $.ajax({
         url: '/upload',//請求路徑
         type: 'POST',
         data: formData,
         contentType: false,//為了讓瀏覽器根據(jù)傳入的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("與服務(wù)器通信發(fā)生錯誤");
         }
         });
         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數(shù)據(jù)格式(主要用在上傳功能中)的中間件
        //文檔:https://github.com/expressjs/multer/blob/master/doc/README-zh-cn.md
        const multer = require('multer')
        const app = express()
        //配置express的靜態(tài)目錄
        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) {
         //圖片已經(jīng)被放入到服務(wù)器里,且req也已經(jīng)被upload中間件給處理好了(加上了file等信息)
         //線上的也就是服務(wù)器中的圖片的絕對地址
         var url = '/uploadImgs/' + req.file.filename
         res.json({
         code : 200,
         data : url
         })
        });
        http.createServer(app).listen(3000,()=>{
         console.log('server is listening')
        })

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

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

        總結(jié)

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

        聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        使用express+multer實現(xiàn)node中的圖片上傳功能

        使用express+multer實現(xiàn)node中的圖片上傳功能:下文給大家介紹使用express+multer實現(xiàn)node中的圖片上傳功能,具體內(nèi)容介紹如下所示: 在前端中,我們使用ajax來異步上傳圖片,使用file-input來上傳圖片,使用formdata對象來處理圖片數(shù)據(jù),post到服務(wù)器中 在node中使用multer中間件來對上傳路由接
        推薦度:
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 中文字幕亚洲免费无线观看日本| 亚洲午夜未满十八勿入网站2| 亚洲国产成人无码av在线播放| 免费观看男人吊女人视频| 好看的电影网站亚洲一区| 免费观看91视频| 亚洲男人天堂av| 3344永久在线观看视频免费首页| 色婷婷六月亚洲婷婷丁香| 曰批全过程免费视频播放网站 | 国产免费的野战视频| 亚洲国产精品综合久久网各| 成年免费大片黄在线观看岛国 | 免费看一级一级人妻片| 中文国产成人精品久久亚洲精品AⅤ无码精品 | 8x成人永久免费视频| 亚洲精品第一综合99久久| 成人免费看片又大又黄| 午夜亚洲国产精品福利| 久久久久亚洲爆乳少妇无| 无码少妇精品一区二区免费动态 | ww在线观视频免费观看w| 亚洲AV中文无码字幕色三| 最近中文字幕无免费| 亚洲国产乱码最新视频| 亚洲国产成人影院播放| 人人揉揉香蕉大免费不卡| 丁香婷婷亚洲六月综合色| 免费在线黄色网址| 91精品视频在线免费观看| 亚洲日韩精品无码专区加勒比| 亚洲AV中文无码乱人伦| 69视频免费在线观看| WWW国产亚洲精品久久麻豆| 亚洲毛片αv无线播放一区| 免费不卡视频一卡二卡| 日韩精品视频在线观看免费| 亚洲成人网在线播放| 免费人成网站在线高清| 99久久免费精品视频| 亚洲欧美日韩一区二区三区在线 |