<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
        當(dāng)前位置: 首頁 - 科技 - 知識百科 - 正文

        express、multer實現(xiàn)node中圖片上傳功能

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

        express、multer實現(xiàn)node中圖片上傳功能

        express、multer實現(xiàn)node中圖片上傳功能:在前端中,我們使用ajax來異步上傳圖片,使用file-input來上傳圖片,使用formdata對象來處理圖片數(shù)據(jù),post到服務(wù)器中,在node中使用multer中間件來對上傳路由接口進(jìn)行處理。本文主要和大家介紹使用express+multer實現(xiàn)node中的圖片上傳功能,需要的朋
        推薦度:
        導(dǎo)讀express、multer實現(xiàn)node中圖片上傳功能:在前端中,我們使用ajax來異步上傳圖片,使用file-input來上傳圖片,使用formdata對象來處理圖片數(shù)據(jù),post到服務(wù)器中,在node中使用multer中間件來對上傳路由接口進(jìn)行處理。本文主要和大家介紹使用express+multer實現(xiàn)node中的圖片上傳功能,需要的朋
        在前端中,我們使用ajax來異步上傳圖片,使用file-input來上傳圖片,使用formdata對象來處理圖片數(shù)據(jù),post到服務(wù)器中,在node中使用multer中間件來對上傳路由接口進(jìn)行處理。本文主要和大家介紹使用express+multer實現(xiàn)node中的圖片上傳功能,需要的朋友可以參考下,希望能幫助到大家。

        multer文檔

        package.json

        html部分

        <body>
        <p class="form-group">
         <label>File input:</label>
         <input type="file" name="file" id="file">
         <p id="result"></p>
         <img id="img" src="">
         </p>
         <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")
         //因為準(zhǔn)備用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)
        }

        聲明:本網(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中圖片上傳功能:在前端中,我們使用ajax來異步上傳圖片,使用file-input來上傳圖片,使用formdata對象來處理圖片數(shù)據(jù),post到服務(wù)器中,在node中使用multer中間件來對上傳路由接口進(jìn)行處理。本文主要和大家介紹使用express+multer實現(xiàn)node中的圖片上傳功能,需要的朋
        推薦度:
        標(biāo)簽: 上傳 實現(xiàn) 上傳圖片
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 亚洲精品国产成人中文| 亚洲情A成黄在线观看动漫软件| 亚洲国产精品丝袜在线观看| 国产亚洲欧洲Aⅴ综合一区| 亚洲精品自拍视频| 亚洲一级毛片免费观看| 国产极品粉嫩泬免费观看| 亚洲AV无码欧洲AV无码网站| 亚洲av无码成人精品国产| 巨胸喷奶水www永久免费 | 极品美女一级毛片免费| 亚洲免费电影网站| 亚洲伊人精品综合在合线| 一级特黄录像免费播放肥| 日韩a在线观看免费观看| 亚洲av日韩av高潮潮喷无码| 美女无遮挡免费视频网站| 国产片AV片永久免费观看| 国产精品69白浆在线观看免费| 亚洲三级在线免费观看| 精品国产麻豆免费人成网站| 国产免费观看a大片的网站| 亚洲人和日本人jizz| 麻豆国产精品入口免费观看| 亚洲国产精品日韩在线| 久久久久久AV无码免费网站| 亚洲情a成黄在线观看| 午夜亚洲乱码伦小说区69堂| 女人18毛片特级一级免费视频| 亚洲欧洲春色校园另类小说| 性色av免费观看| sss在线观看免费高清| 亚洲成av人在片观看| 免费成人高清在线视频| 亚洲三级在线观看| 久久亚洲国产成人精品无码区| 亚洲一区在线免费观看| 日韩在线视精品在亚洲| 日本免费电影一区| 毛片免费在线观看| 亚洲va中文字幕|