html5+nodejs多文件上传
来源:互联网 发布:java函数名命名规则 编辑:程序博客网 时间:2024/05/16 04:28
最近学习文件上传,网上例子大多数是HTML5+python的,可惜本人不会python,暂时也没有时间和兴趣研究python,所以用node.js做后台接收文件上传。
写了一个简单的例子,在这里分享给大家。
项目目录如下:
|__fileupload
|__public // 静态资源目录
|__index.html
|__upload.js
|__ uploadfiles // 文件上传目录
|__server.js // node.js服务器启动文件
- node server.js 启动项目
index.html
<!DOCTYPE html><html><head> <title>使用XMLHttpRequest上传文件</title></head><body><form id="form1" enctype="multipart/form-data" method="post" action="upload.php"> <div class="row"> <label for="fileToUpload">Select a File to Upload</label> <input type="file" name="fileToUpload" id="fileToUpload" onchange="fileSelected();" multiple/> </div> <div id="fileName"></div> <div id="fileSize"></div> <div id="fileType"></div> <div class="row"> <input type="button" onclick="uploadFile()" value="Upload" /> </div> <div id="progressNumber"></div></form><script type="application/javascript" src="upload.js"></script></body></html>
upload.js
function fileSelected() { var file = document.getElementById('fileToUpload').files[0]; if (file) { var fileSize = 0; if (file.size > 1024 * 1024) fileSize = (Math.round(file.size * 100 / (1024 * 1024)) / 100).toString() + 'MB'; else fileSize = (Math.round(file.size * 100 / 1024) / 100).toString() + 'KB'; document.getElementById('fileName').innerHTML = 'Name: ' + file.name; document.getElementById('fileSize').innerHTML = 'Size: ' + fileSize; document.getElementById('fileType').innerHTML = 'Type: ' + file.type; }}function uploadFile() { var xhr = new XMLHttpRequest(); var fd = new FormData(); fd.append("author", "connie"); fd.append("name", "Html 5 File API/FormData"); var files = document.getElementById('fileToUpload').files; // 单文件上传 // fd.append("fileToUpload", files[0]); // 多文件上传 for (key in files){ fd.append("fileToUpload", files[key]); } /* event listners */ xhr.upload.addEventListener("progress", uploadProgress, false); xhr.addEventListener("load", uploadComplete, false); xhr.addEventListener("error", uploadFailed, false); xhr.addEventListener("abort", uploadCanceled, false); /* Be sure to change the url below to the url of your upload server side script */ xhr.open("POST", "upload"); xhr.send(fd);}function uploadProgress(evt) { if (evt.lengthComputable) { var percentComplete = Math.round(evt.loaded * 100 / evt.total); document.getElementById('progressNumber').innerHTML = percentComplete.toString() + '%'; } else { document.getElementById('progressNumber').innerHTML = 'unable to compute'; }}function uploadComplete(evt) { /* This event is raised when the server send back a response */ alert(evt.target.responseText);}function uploadFailed(evt) { alert("There was an error attempting to upload the file.");}function uploadCanceled(evt) { alert("The upload has been canceled by the user or the browser dropped the connection.");}
server.js
/** * Created by Administrator on 2017/6/5. */var express = require('express'), path = require('path'), app = express(), fs = require('fs'), multiparty = require('multiparty'); // FormData解析工具var target_path;var config = { upload_dir: 'uploadfiles'}// 引入静态文件代码app.use(express.static(path.join(__dirname, 'public')));// 文件上传urlapp.post('/upload', function(req, res){ var form = new multiparty.Form(); form.parse(req, function (err, fields, files) { if (err){ throw err } console.log(fields); console.log(files); // fields显示非文件类型的所有key、value值 Object.keys(fields).forEach(function(name) { console.log('got field named ' + name); }); for (key in files){ files[key].forEach(function (file, index) { target_path = config.upload_dir + '/' + file.originalFilename; try { // 读取缓存文件,同时写入所需上传的目录 fs.createReadStream(file.path).pipe(fs.createWriteStream(target_path)); console.log(file.originalFilename); console.log('Upload completed!'); res.json({infor:"success"}) } catch (err){ res.json({err:err}) } }) } });});app.listen(8080);console.log('Listening on port 8080');
阅读全文
0 0
- html5+nodejs多文件上传
- html5多文件上传
- Nodejs+HTML5兼容IE789的大文件上传完整版
- html5实现多文件上传
- html5多文件上传代码
- HTML5 FormData多文件上传
- 关于nodejs接受多文件上传问题
- nodejs express 上传文件
- NODEJS 上传文件
- nodejs 安装 上传文件
- Nodejs 文件上传
- nodeJs 接收上传文件
- nodejs 上传文件
- nodejs文件上传
- NodeJs上传文件至七牛
- Nodejs文件上传
- nodejs multer上传文件
- nodejs 之文件上传
- sklearn与GBDT入门案例
- FreeLine实现AndroidStudio秒级编译
- 微信对接token验证失败的问题
- openvpn注销用户证书
- SDUT-数据结构实验之图论七:驴友计划
- html5+nodejs多文件上传
- Android Studio 开发调试简介
- Frogger POJ
- 西门子S7-300PLC的置位/复位指令及示例
- 采购订单相关Table
- openvpn客户端获得固定IP
- linux下的日志采集---rsyslog
- 最简单生产消费者模型理解(线程同步,共享资源,信号
- 浅谈URLEncoder编码算法