亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

Node.js開發教程之基于OnceIO框架實現文件上傳和驗證功能

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

OnceIO 是 OnceDoc 企業內容(網盤)的底層Web框架,它可以實現模板文件、靜態文件的全緩存,運行起來完全不需要I/O操作,并且支持客戶端緩存優化,GZIP壓縮等(只在第一次壓縮),擁有非常好的性能,為您節約服務器成本。它的模塊化功能,可以讓你的Web進行分布式存儲,即一個擴展包里即包含前端、后端和數據庫定義,只需通過添加/刪除目錄的方式就可實現功能刪減,實現真正的模塊化擴展。這里是介紹如何使用OnceIO的一系列文章。

在這一章節中,我們將為大家演示如何使用 OnceIO 實現文件上傳功能。

在網頁文件中構建表單

以一個只有文件上傳功能的簡單網頁 file.html 為例:

<!DOCTYPE html><html><body><form method="post" enctype="multipart/form-data" action="/file/upload"><input type="file" name="file" /><br><input type="submit" value="Upload" /></form></body></html>

瀏覽器顯示效果是這樣的:

 

點擊空白長條或“瀏覽…”按鈕可以打開文件瀏覽窗口選擇需要上傳的文件:

 

建立服務器接收文件邏輯

服務器文件 websvr.js 代碼是這樣的:

var fs = require('fs')var path = require('path')var onceio = require('../onceio/onceio')var app = onceio()app.get('/', function(req, res){res.render('file.html')})app.file('/file/upload', function(req, res) {var fileInfo = req.files.file || {}fs.link(fileInfo.path, path.join('./fileStore', fileInfo.name))res.send('File Uploaded Successfully')}).before(function(req, res) {var contentLength = req.headers['content-length'] || 0if (contentLength > 1048576) {res.send({ error: 'Error: File Size Limit (1 MB) Exceeded' })} else {return true}})

var fs = require('fs') 和 var path = require('path') 分別導入了 Node.js 提供的用于操作文件的文件系統(fs)模塊和用于處理文件路徑的 path 模塊。

app.file(path, callback).before(callback) 相當于 app.use(path, callback, {file: true}).before(callback) ,是一個處理上傳的文件的中間件。

文件被上傳后,它的大小、存放地址、名稱、格式和修改時間五項信息會被放在 req.files 的 file 屬性里(名稱是 type 為 'file' 的 input 標簽中 name 的值),它的尺寸信息會被放在 req.headers 的 content-length 屬性里。

before函數

before是OnceIO與其它Web框架的主要區別之一。它可以在文件接收之前就對文件進行一些基本驗證,如大小、類型等,以求獲得最侍性能。return true 表示驗證通并開始接收文件,否則就關閉連接,取消上傳。在 before 中,req.session對象是不可用的,因為session可能存在文件或數據庫redis中,取得session是一個異步過程需要時間。而before函數需要立刻對文件合法性做出判斷。

在這個例子中before回調函數根據 req.headers 中的 content-length 判斷上傳的文件是否超出了尺寸限制(開發人員可以通過修改 if 語句中的常數改變文件上傳尺寸上限,content-length 單位為 byte,1024 * 1024 即代表 1 MB),如果超出了,文件不會被上傳,服務器返回錯誤信息;如果沒有超出,函數返回值為 true,服務器繼續執行 app.file 中的回調函數,將文件從臨時地址轉移到指定存儲地址,文件上傳到這里就完成了。

解決文件重名問題

我們目前的服務器程序是無法解決文件重名問題的。如果用戶上傳了重名的文件,服務器將會返回文件已經存在的錯誤。為了解決這個問題,我們可以在文件的主文件名和拓展名之間加入一個時間戳,進行這個處理的函數代碼如下:

var timestampName = function(fileName){// get filename extensionvar extName = path.extname(fileName) // get base name of the filevar baseName = path.basename(fileName, extName)// insert timestamp between base name and filename extension// the plus sign ('+') before new Date() converts it into a numberreturn baseName + +new Date() + extName}

再把 fs.link 語句里的 fileInfo.name 替換為 timestampName(fileInfo.name):

fs.link(fileInfo.path, path.join('./fileStore', timestampName(fileInfo.name)))

改進后的服務器程序就能允許用戶上傳重名文件了,以上傳 5 次名為 'cache_workflow.png' 的文件為例,服務器的文件存儲地址中會出現 5 個名稱都以 'cache_workflow' 開頭但時間戳不同的文件:

 

OnceIO地址: https://github.com/OnceDoc/onceio

示例源碼: https://github.com/OnceDoc/OnceAcademy/tree/master/Lesson14

以上所述是小編給大家介紹的Node.js開發教程之基于OnceIO框架實現文件上傳和驗證,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产日产欧美a一级在线| 精品亚洲一区二区三区四区五区| 欧美成人激情图片网| 欧美日韩综合视频| 91chinesevideo永久地址| 国产精品精品视频一区二区三区| 国产精品久久久久久中文字| 日韩精品免费在线观看| 91美女片黄在线观看游戏| 日本欧美一二三区| 狠狠色狠色综合曰曰| 欧美精品午夜视频| 国产福利视频一区| 欧美整片在线观看| 91爱爱小视频k| 欧美成人精品一区| 国产香蕉一区二区三区在线视频| 国产日韩av高清| 性色av一区二区三区在线观看| 色综合天天综合网国产成人网| 日产精品久久久一区二区福利| 久久久久久成人| 成人av电影天堂| 欧美大胆a视频| 97国产精品视频| 欧美日韩在线影院| 97国产精品视频| 国产成人精品网站| 91国内产香蕉| 国产亚洲视频中文字幕视频| 国产成+人+综合+亚洲欧美丁香花| 精品日本高清在线播放| 国产精品美女久久| 色综合久久天天综线观看| 亚洲精品视频二区| 日韩欧美中文免费| 欧美激情va永久在线播放| 欧美午夜性色大片在线观看| 久久99国产精品自在自在app| 欧美在线观看一区二区三区| 日韩亚洲欧美中文高清在线| 国产精品日韩久久久久| 97视频网站入口| 国产视频久久久久| 日韩成人中文字幕在线观看| 亚洲天堂影视av| 91亚洲精华国产精华| 欧美激情视频在线| 免费91在线视频| 亚洲天堂免费在线| 久久亚洲精品网站| 国产精品女人久久久久久| 国产精品美女www爽爽爽视频| 美女啪啪无遮挡免费久久网站| 亚洲国产日韩欧美在线99| 欧美性资源免费| 日韩经典中文字幕| 91热福利电影| 欧美亚洲成人网| 国产丝袜一区二区三区| 国产成人精品日本亚洲| 亚洲一区二区三区久久| 亚洲图片欧美日产| 欧美午夜激情视频| 黑人精品xxx一区一二区| 在线播放国产精品| 精品在线观看国产| 国产午夜一区二区| 国产网站欧美日韩免费精品在线观看| 日日狠狠久久偷偷四色综合免费| 国产成+人+综合+亚洲欧美丁香花| 国产精品成人av在线| 国内外成人免费激情在线视频网站| 欧美老女人在线视频| 亚洲欧美成人在线| 狠狠爱在线视频一区| 精品在线小视频| 成人av色在线观看| 亚洲精品视频在线观看视频| 欧美大荫蒂xxx| 5566成人精品视频免费| 日韩美女福利视频| 欧美激情视频给我| 国产成人福利夜色影视| 欧美人与物videos| 91久久精品日日躁夜夜躁国产| 亚洲欧美日韩精品久久奇米色影视| 91亚洲国产成人久久精品网站| 91免费综合在线| 亚洲aaaaaa| 在线观看国产精品淫| 亚洲人成网站777色婷婷| 91伊人影院在线播放| 不卡在线观看电视剧完整版| 亚洲国产美女久久久久| 久久在线精品视频| 亚洲在线视频观看| 久久精品国产欧美亚洲人人爽| 亚洲一区av在线播放| 欧美激情视频网址| 欧美大片免费观看| 日韩av在线影视| 亚洲精品视频在线观看视频| 国产日韩欧美夫妻视频在线观看| 国产亚洲精品久久久久久| 亚洲精品一区二三区不卡| 97国产精品人人爽人人做| 国产精品久久国产精品99gif| 91精品国产91久久久久久最新| 国产精品三级久久久久久电影| 91久久久久久久久久久| 一本久久综合亚洲鲁鲁| 久久久久亚洲精品成人网小说| 国产成人免费av| 国产精品www网站| 欧美在线视频观看免费网站| 成人做爰www免费看视频网站| 92国产精品视频| 日韩最新av在线| 欧美性感美女h网站在线观看免费| 亚洲天堂日韩电影| 国产欧美精品日韩| 国产91在线高潮白浆在线观看| 欧美最顶级丰满的aⅴ艳星| 国产精品视频导航| 国产亚洲欧美日韩美女| 亚洲午夜久久久久久久| 日本精品视频在线观看| 欧美—级a级欧美特级ar全黄| 成人av资源在线播放| 8x拔播拔播x8国产精品| 亚洲第一av网| 日本精品免费一区二区三区| 精品亚洲永久免费精品| 亚洲黄色www| 国产精品视频xxx| 精品综合久久久久久97| 欧美激情videoshd| 亚洲人成在线免费观看| 97国产真实伦对白精彩视频8| 国产亚洲欧洲高清一区| 久久久这里只有精品视频| 精品av在线播放| 伊人青青综合网站| 久久精品国产成人| 日本国产欧美一区二区三区| www.国产精品一二区| 欧美视频二区36p| 欧美做受高潮1| 色综合久久88色综合天天看泰| 国产精品第一视频| 91色在线视频| 亚洲国产精品悠悠久久琪琪| 成年人精品视频| 91日本在线观看| 久久91超碰青草是什么| 色综合久久88色综合天天看泰| 成人免费高清完整版在线观看| 久久精品成人一区二区三区| 亚洲欧美一区二区三区久久| 欧美在线视频观看免费网站| 日韩免费看的电影电视剧大全| 俺也去精品视频在线观看| 亚洲色图综合网|