這篇文章node.js+Android(使用HttpURLConnection和HttpClient)實現文件上傳(見 http://www.linuxidc.com/Linux/2012-02/53532.htm ),使用的是formidable,上篇文章介紹了node.js connect 安裝、介紹與實例(見 http://www.linuxidc.com/Linux/2012-02/53528.htm ),那就用connect寫一個上傳的例子。
主程序代碼如下,保存為bodyParser.js,放在敲安裝命令的目錄下:
[javascript]
- 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]
- <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)實現文件上傳,需要的話查看這篇文章 見http://www.linuxidc.com/Linux/2012-02/53532.htm。