<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
        主站蜘蛛池模板: 在线观看成人免费视频不卡| 国产精品网站在线观看免费传媒| 99在线精品视频观看免费| 亚洲福利在线观看| 久久免费精彩视频| 亚洲av无码一区二区三区不卡| 国产免费阿v精品视频网址| 亚洲精品无码高潮喷水在线| 免费播放在线日本感人片| 亚洲自偷自偷在线制服| 在线观看免费黄网站| 亚洲AV永久青草无码精品| 午夜爽爽爽男女免费观看影院| 亚洲欧洲日产国码二区首页| 成人午夜免费福利视频| 国产AV旡码专区亚洲AV苍井空| 四虎在线视频免费观看| 免费激情网站国产高清第一页| 亚洲精品无码99在线观看 | 中文字幕在线免费观看| 337p欧洲亚洲大胆艺术| 无码视频免费一区二三区| 国产综合激情在线亚洲第一页| 精品亚洲一区二区三区在线播放| 免费国产污网站在线观看| 亚洲性69影院在线观看| 在线看片人成视频免费无遮挡| 日韩在线视频播放免费视频完整版| 亚洲精品无码鲁网中文电影| 波多野结衣在线免费观看| 亚洲av色香蕉一区二区三区蜜桃| 亚洲天堂中文字幕在线| 99蜜桃在线观看免费视频网站| 亚洲午夜精品一区二区麻豆| 亚洲精品一级无码鲁丝片| 最近中文字幕完整版免费高清| 亚洲人成网站在线播放2019| 亚洲熟妇无码八AV在线播放| 国产1024精品视频专区免费| 日本精品久久久久久久久免费| 久久久久久亚洲Av无码精品专口|