• <fieldset id="8imwq"><menu id="8imwq"></menu></fieldset>
  • <bdo id="8imwq"><input id="8imwq"></input></bdo>
    最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題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關鍵字專題關鍵字專題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
    當前位置: 首頁 - 科技 - 知識百科 - 正文

    node中間層實現文件上傳功能

    來源:懂視網 責編:小采 時間:2020-11-27 22:13:26
    文檔

    node中間層實現文件上傳功能

    node中間層實現文件上傳功能:一般情況下,前端的文件上傳一般都是通過form表單的(<input type=file />)來完成文件的上傳,如果使用node中間層完成跨域,文件的上傳就需要在node中間層處理成可讀流,轉成formData完成轉發。 一、form表單文件上傳 這是最常見的文件上傳方
    推薦度:
    導讀node中間層實現文件上傳功能:一般情況下,前端的文件上傳一般都是通過form表單的(<input type=file />)來完成文件的上傳,如果使用node中間層完成跨域,文件的上傳就需要在node中間層處理成可讀流,轉成formData完成轉發。 一、form表單文件上傳 這是最常見的文件上傳方

    一般情況下,前端的文件上傳一般都是通過form表單的(<input type="file" />)來完成文件的上傳,如果使用node中間層完成跨域,文件的上傳就需要在node中間層處理成可讀流,轉成formData完成轉發。

    一、form表單文件上傳

      這是最常見的文件上傳方式,通過form表單實現,簡單實用,設置一下method、enctype、action屬性就可以了,多文件上傳需要設置multiple屬性(部分瀏覽器支持還是有些問題的)。

    <form method="post" enctype="multipart/form-data" action="/api/upload">
     <input type="text" name="username">
     <input type="password" name="password">
     <input type="file" name="file">
     <input type="submit">
    </form>

    二、FormData實現文件上傳

      FormData對象用以將數據編譯成鍵值對,以便向后臺發送數據。其主要用于發送表單數據,但亦可用于發送帶鍵數據(keyed data),而獨立于表單使用。對部分瀏覽器對multiple屬性不支持的情況,可以使用formData的提交方式完成。

    <!-- 獲取上傳文件轉成formData類型的文件 -->
    <input multiple id="file" name="file" type="file" />
    <button id="btn">提交</button>
    
    const oFile = document.getElementById('file')
    const oBtn = document.getElementById('btn')
    
    oBtn.addEventListener('click', () => {
     files = oFile.files
     const formData = new FormData()
     formData.append('file', files[0])
     formData.append('file1', files[1])
    
     fetch('/api/upload', {
     method: "POST",
     body: formData
     })
    })

    使用fetch請求不要設置Content-Type,否則無法請求

    fetch請求默認是不帶cookie 

    三、node中間層完成文件上傳跨域

      跨域是因為瀏覽器的同源策略造成,跨域的方法有很多中,這里使用的是node中間層代理完成(服務端之間的請求是不存在跨域問題)。

      node無法直接解析上傳的文件,需要引入拓展包connect-multiparty完成,這樣就可以拿到文件數據。

      拿到上傳文件,需要在node中轉發請求后臺server,這里的文件不能直接發給后臺,需要將上傳的文件使用fs.createReadStream轉成可讀流,同時引入 form-data 包(node環境是沒有formData對象的),這樣就可以實現node中間層轉發文件類型

      node部分代碼:

    const fs = require('fs')
    const path = require('path')
    const FormData = require('form-data')
    const express = require('express')
    const fetch = require('node-fetch')
    const router = express.Router()
    const multipart = require('connect-multiparty');
    var multipartMiddleware = multipart()
    
    router.post('/upload', multipartMiddleware, function (req, res) {
     // console.log(req.body, req.files);
    
     const { path: filePath, originalFilename } = req.files.file
     const newPath = path.join(path.dirname(filePath), originalFilename)
    
     fs.rename(filePath, newPath, function (err) {
     if (err) {
     return;
     }
     else {
     const file = fs.createReadStream(newPath)
     const form = new FormData()
     form.append('file', file)
    
     fetch('http://localhost:8080/upload', {
     method: "POST",
     body: form
     })
     }
     })
     res.json({})
    });
    
    module.exports = router;

    注意:

  • node無法直接解析上傳文件,需要引入npm包connect-multiparty中間件,或者引入npm包multiparty
  • node拿到文件,需要使用fs.createReadStream轉成可讀流
  • node環境沒有formData對象,需要引入npm包form-data
  • fetch請求提交formData數據,不能設置Comtemt-Type
  • 最后給大家附上完整的代碼: node中間層實現文件上傳

    總結

    以上所述是小編給大家介紹的node中間層實現文件上傳功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!

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

    文檔

    node中間層實現文件上傳功能

    node中間層實現文件上傳功能:一般情況下,前端的文件上傳一般都是通過form表單的(<input type=file />)來完成文件的上傳,如果使用node中間層完成跨域,文件的上傳就需要在node中間層處理成可讀流,轉成formData完成轉發。 一、form表單文件上傳 這是最常見的文件上傳方
    推薦度:
    標簽: 文件 中間 nod
    • 熱門焦點

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: 亚洲中文字幕久久精品无码APP| 中日精品无码一本二本三本| 四虎国产精品成人| 精品久久久久久亚洲| 亚洲AV无码国产精品色午友在线 | 97精品伊人久久大香线蕉app| 婷婷国产成人精品一区二| 国产精品成人观看视频网站| 久久九九青青国产精品| 99精品一区二区三区无码吞精| 无码精品人妻一区二区三区漫画| 日本一区二区三区精品国产| 国产精品视频九九九| 亚洲综合精品一二三区在线| 国产2021精品视频免费播放| 久久99精品国产麻豆| 无码国内精品久久人妻| 亚洲国产精品综合久久网络| 国产精品自在在线午夜福利 | 亚洲精品乱码久久久久久中文字幕 | 久久精品国产一区二区电影| 97精品国产97久久久久久免费| 国产成人精品亚洲日本在线| 国产精品99久久免费观看| 99视频精品全部在线观看| 精品乱码久久久久久久| 老司机亚洲精品影院| 久久夜色精品国产噜噜噜亚洲AV| 亚洲精品无码久久一线| 亚洲一区爱区精品无码| 亚洲国产精品无码专区| 无码精品人妻一区二区三区人妻斩| 亚洲日韩精品无码专区网址 | 久久最新精品国产| 久久99国产精品久久99果冻传媒| jizz国产精品网站| 国产精品福利在线观看| 91精品国产色综久久| 国产精品天干天干在线综合 | 桃花岛精品亚洲国产成人| 成人精品一区二区三区免费看|