欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

NodeJS與HTML5相結(jié)合實現(xiàn)拖拽多個文件上傳到服務(wù)器的實現(xiàn)方法

 更新時間:2016年07月26日 17:07:55   作者:但丁之曲  
這篇文章主要介紹了NodeJS與HTML5相結(jié)合實現(xiàn)拖拽多個文件上傳到服務(wù)器的實現(xiàn)方法的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下

實現(xiàn)多文件拖拽上傳的簡易Node項目,可以在github上下載,你可以先下載下來:https://github.com/Johnharvy/upLoadFiles/

解開下載下的zip格式包,建議用webstom 運行該項目,通過app.js啟動項目,如果提示找不到node.exe執(zhí)行環(huán)境,請指定好你的node.exe安裝位置。這里我用的express框架是3.21.2版本。

我們來簡單介紹下拖拽效果是怎么實現(xiàn)的。

這里先看代碼:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<script src="js/jquery.js"></script>
<script src="js/EventUtil.js"></script>
<title>uploadFile</title>
<style>
#a1{width:100px;height:100px;background: #aaaaaa;text-align:center;line-height:100px;color:rgba(81, 49, 202, 0.72);
margin:150px auto;}
</style>
</head>
<body>
<div id="a1">拖拽到此</div>
<div id="out-input"></div>
<script>
var a1=document.getElementById("a1");
function handleEvent(event){
var info ="",
output= document.getElementById("out-input"),
files,i,len;
EventUtil.preventDefault(event); //阻止事件的默認(rèn)行為
var formData =new FormData();
if(event.type == "drop"){
files=event.dataTransfer.files;
i = 0;
len= files.length;
while( i< len){
info += files[i].name +"("+ files[i].type + "," +files[i].size +"bytes)<br/>";
formData.append("file"+i,files[i]);
i++;
}
output.innerHTML = info;
$.ajax({
type:"post",
url:"/uploadFile",
data:formData,
async: false,
cache: false,
contentType: false,
processData: false, //此處指定對上傳數(shù)據(jù)不做默認(rèn)的讀取字符串的操作
success:function(rs){
console.log(rs);
},
error:function(r){
alert("文件上傳出錯!");
}
});
}
}
EventUtil.addHandler(a1, "dragenter", handleEvent);
EventUtil.addHandler(a1, "dragover", handleEvent);
EventUtil.addHandler(a1, "drop", handleEvent);
</script>
</body>
</html>

   html內(nèi)容很簡單,一個顯示允許的拖拽范圍,一個用來顯示上傳文件內(nèi)容的div塊。

Js部分:

這里我準(zhǔn)備了一個EventUtil接口對象,你也可以把它看成處理事件的很小的庫,它的作用是封裝了各個瀏覽器綁定相同事件的不同方法,為了實現(xiàn)各瀏覽器通用的事件綁定方法,統(tǒng)一用EventUtil對象來實現(xiàn),你可以簡單看下它的實現(xiàn)代碼,非常簡單。

當(dāng)瀏覽器檢測到拖拽的三種事件情況,“dragenter”,“dragover”,“drag"默認(rèn)的行為會被阻止,當(dāng)為”drag“情況時執(zhí)行我們的自定義事件。

因為我們上傳的是文件,所以這里用到了FormData的實例,通過append()添加文件到該對象中成為隊列文件,上傳到服務(wù)器端后會按隊列順序被解析成屬性對象。事件中通過”event.dataTransfer.files“來獲取事件中存儲的文件。

這里還有一點需要注意的是jquery的ajax方法在上傳文件對象時需要配置processData為false,意指不使用默認(rèn)的讀取字符串的操作。原因是默認(rèn)情況下,通過data選項傳遞進(jìn)來的數(shù)據(jù),如果是一個對象(技術(shù)上講只要不是字符串),都會處理轉(zhuǎn)化成一個查詢字符串,以配合默認(rèn)內(nèi)容類型 "application/x-www-form-urlencoded"。如果要發(fā)送 DOM 樹信息或其它不希望轉(zhuǎn)換的信息,需要設(shè)置為 false。

文件上傳成功后控制臺會打印”{infor:"success”}“信息。

到此,前端部分結(jié)束,下面我們來看Node.js端的代碼。

文件結(jié)構(gòu)如下:

我們先看路由——app.js里的內(nèi)容:

var express = require('express');
var routes = require('./routes');
var user = require('./routes/user');
var http = require('http');
var path = require('path');
var app = express();
// all environments
app.set('port', process.env.PORT || 3000);
app.set('view engine', 'jade');
app.use(express.favicon());
app.use(express.logger('dev'));
app.use(express.json());
app.use(express.urlencoded());
app.use(express.methodOverride());
app.use(app.router);
app.use(express.static(path.join(__dirname)));
exports.app=app;
var uploadAction=require("./Action/fileUpload");
//路由事件監(jiān)聽
uploadAction.uploadTest.uploadFile();
//文件上傳監(jiān)聽
// development only
if ('development' == app.get('env')) {
app.use(express.errorHandler());
}
app.get('/users', user.list);
http.createServer(app).listen(app.get('port'), function(){
console.log('Express server listening on port ' + app.get('port'));
});

  和初始的app.js有幾點不同,我把app對象導(dǎo)出來以便在fileUpload.js中重復(fù)利用,然后引入了fileUpload.js模塊,并通過該接口對象獲得保存該模塊所有方法的uploadTest對象并調(diào)用uploadFile方法。

好,最后我們來看fileUpload.js文件:

var multipart = require('connect-multiparty');
var App=require("../app");
var path = require('path');
var fs=require("fs");
var app=App.app;
var uploadTest={};
function uploadFile(){
app.post("/uploadFile", multipart(),function(req,res) {
var i=0;
while(i != null){
if(req.files["file"+i]) upLoad(i);
else{ i= null; res.json({infor:"success"});return;}
i++;
}
//上傳隊列文件
function upLoad(index){
var filename = req.files["file"+index].originalFilename || path.basename(req.files["file"+index].path);
//path接口可以指定文件的路徑和文件名稱,"\結(jié)尾默認(rèn)為路徑,字符串結(jié)尾默認(rèn)為文件名"
var targetPath = path.dirname("") + '/public/uploadFiles/' + filename;
//fs創(chuàng)建指定路徑的文件并將讀取到的文件內(nèi)容寫入
fs.createReadStream(req.files["file"+index].path).pipe(fs.createWriteStream(targetPath));
}
});
}
uploadTest.uploadFile=uploadFile;
exports.uploadTest=uploadTest;

  nodeJs總是非常簡便威猛的,而且具有高度的可創(chuàng)性,這也是我喜歡它的理由。我們看到這里的關(guān)鍵代碼其實很少,我簡單介紹下實現(xiàn)文件上傳的邏輯過程:

•獲取上傳文件的文件名

•設(shè)置文件的存儲位置,以及文件名稱

•讀取文件的內(nèi)容流并創(chuàng)建新文件寫入內(nèi)容流

為了實現(xiàn)上傳多個文件,我還做了一些匹配操作,很直觀,不難理解。

文件上傳成功后,會出現(xiàn)在public文件下的uploadFiles文件下。

文件中所用到的模塊都記錄在package.json中,可以通過進(jìn)入package.json的同級目錄地址通過指令”npm install“安裝。如果是直接運行g(shù)ithub上下載的工程文件,就不用再安裝了。

以上所述是小編給大家介紹的NodeJS與HTML5相結(jié)合實現(xiàn)拖拽多個文件上傳到服務(wù)器的實現(xiàn)方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • 如何在Nodejs中使用模塊fs文件系統(tǒng)

    如何在Nodejs中使用模塊fs文件系統(tǒng)

    這篇文章主要介紹了如何在Nodejs中使用模塊fs文件系統(tǒng),對nodejs感興趣的同學(xué),可以參考下
    2021-05-05
  • Nodejs Post請求報socket hang up錯誤的解決辦法

    Nodejs Post請求報socket hang up錯誤的解決辦法

    這篇文章主要介紹了Nodejs Post請求報socket hang up錯誤的解決辦法,本文因少加了headers字段信息導(dǎo)致出現(xiàn)這個錯誤,本文給出了一個完整的實現(xiàn)代碼,需要的朋友可以參考下
    2014-09-09
  • Node 創(chuàng)建第一個服務(wù)器應(yīng)用的操作方法

    Node 創(chuàng)建第一個服務(wù)器應(yīng)用的操作方法

    Node.js是一個基于Chrome V8引擎的JavaScript運行環(huán)境,可以用于構(gòu)建高性能的網(wǎng)絡(luò)應(yīng)用程序,它采用事件驅(qū)動、非阻塞I/O模型,使得程序可以以高效地方式處理并發(fā)請求,這篇文章主要介紹了Node 創(chuàng)建第一個服務(wù)器應(yīng)用,需要的朋友可以參考下
    2024-02-02
  • 在Node.js下運用MQTT協(xié)議實現(xiàn)即時通訊及離線推送的方法

    在Node.js下運用MQTT協(xié)議實現(xiàn)即時通訊及離線推送的方法

    這篇文章主要介紹了在Node.js下運用MQTT協(xié)議實現(xiàn)即時通訊及離線推送的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-01-01
  • nodejs通過phantomjs實現(xiàn)下載網(wǎng)頁

    nodejs通過phantomjs實現(xiàn)下載網(wǎng)頁

    這篇文章主要介紹了nodejs通過phantomjs實現(xiàn)下載網(wǎng)頁的方法,有需要的小伙伴可以參考下。
    2015-05-05
  • node.js使用http模塊創(chuàng)建服務(wù)器和客戶端完整示例

    node.js使用http模塊創(chuàng)建服務(wù)器和客戶端完整示例

    這篇文章主要介紹了node.js使用http模塊創(chuàng)建服務(wù)器和客戶端,結(jié)合完整示例形式分析了node.js基于http模塊實現(xiàn)客戶端與服務(wù)器端交互的相關(guān)操作技巧,需要的朋友可以參考下
    2020-02-02
  • Node.js程序中的本地文件操作用法小結(jié)

    Node.js程序中的本地文件操作用法小結(jié)

    這篇文章主要介紹了Node.js程序中的本地文件操作用法小結(jié),作為運行在服務(wù)器端的JavaScript解釋器,Node中自然擁有操作本地文件的方法,需要的朋友可以參考下
    2016-03-03
  • 詳解nodejs模板引擎制作

    詳解nodejs模板引擎制作

    本篇文章主要介紹了nodejs模板引擎制作 ,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • nodejs用gulp管理前端文件方法

    nodejs用gulp管理前端文件方法

    本篇文章給大家分享了nodejs用gulp管理前端文件的步驟方法以及優(yōu)缺點分析,有興趣的朋友參考下。
    2018-06-06
  • Node.js利用Express實現(xiàn)用戶注冊登陸功能(推薦)

    Node.js利用Express實現(xiàn)用戶注冊登陸功能(推薦)

    這篇文章主要介紹了Node.js利用Express實現(xiàn)用戶注冊登陸功能,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-10-10

最新評論