node.js connect 实现文件上传

来源:互联网 发布:怎么解决移动网络屏蔽 编辑:程序博客网 时间:2024/05/16 17:47

上次博客node.js+android(使用HttpURLConnection和HttpClient)实现文件上传,使用的是formidable,上篇博客介绍了node.js connect 安装、介绍与实例,那就用connect写一个上传的例子。

主程序代码如下,保存为bodyParser.js,放在敲安装命令的目录下:

var connect = require('connect');var app = connect()  .use(connect.static(__dirname + '/public'))  .use(connect.bodyParser({uploadDir:__dirname +'/file',keepExtensions:true}))  .use(connect.logger())  .use(function(req, res, next){    if ('GET' != req.method) return next();    res.statusCode = 302;    res.setHeader('Location', 'form.html');    res.end();  })  .use(function(req, res){    res.setHeader('Content-Type', 'text/html');    res.write('<p>thanks ' + req.body.name + '</p>');    res.write('<ul>');console.log(req.body);console.log(req.files);    if (Array.isArray(req.files.images)) {      req.files.images.forEach(function(image){        var kb = image.size / 1024 | 0;        res.write('<li>uploaded ' + image.name + ' ' + kb + 'kb</li>');      });    } else {      var image = req.files.images;      var kb = image.size / 1024 | 0;      res.write('<li>uploaded ' + image.name + ' ' + kb + 'kb</li>');    }    res.end('</ul>');  });app.listen(8080);console.log('Server started on port 8080');
静态文件form.html代码如下,放在bodyParser.js同级的public文件夹下:

<html><body><form action="/" method="post" enctype="multipart/form-data">  <input type="text" name="name" placeholder="Name:" />  <input type="file" name="images" multiple="multiple" />  <input type="submit" value="Upload" /></form></body></html>
代码比较简单,可以查看官方提供的API http://senchalabs.github.com/connect/middleware-bodyParser.html,官方提供的例子https://github.com/senchalabs/connect/blob/1.8.4/examples/bodyParser.js

效果同 node.js+android(使用HttpURLConnection和HttpClient)实现文件上传,需要的话查看这篇博文。

原创粉丝点击