【发布时间】:2016-09-27 09:45:24
【问题描述】:
我正在尝试使用自定义 MultipartEntity 从 Android 应用程序上传图像,该应用程序还会更新 ProgressDialog(这也是我使用已弃用的 MultipartEntity 的原因)。
相关Java代码:
File file = new File(imgPath);
HttpPost post = new HttpPost("http://" + SERVER + "/upload");
MultipartEntity entity = new MyMultipartEntity(new MyMultipartEntity.ProgressListener()
{
public void transferred(long num)
{
publishProgress((int) ((num / (float) totalSize) * 100));
Log.d("DEBUG", num + " - " + totalSize);
}
});
ContentBody cbFile = new FileBody(file, "image/jpeg");
entity.addPart("source", cbFile);
totalSize = entity.getContentLength();
post.setEntity(entity);
HttpResponse response = client.execute(post);
int statusCode = response.getStatusLine().getStatusCode();
if(statusCode == HttpStatus.SC_OK){
String fullRes = EntityUtils.toString(response.getEntity());
Log.d("DEBUG", fullRes);
} else {
Log.d("DEBUG", "HTTP Fail, Response Code: " + statusCode);
}
Node.js 服务器文件:
var fs = require('fs');
var express = require('express');
var app = express();
var multer = require('multer');
var upload = multer(
{
limits: {
fieldNameSize: 999999999,
fieldSize: 999999999
},
dest: 'uploads/' }
);
app.get('/', function(req, res){
res.send(
'<form action="/upload" method="post" enctype="multipart/form-data">'+
'<input type="file" name="source">'+
'<input type="submit" value="Upload">'+
'</form>'
);
});
app.post('/upload', upload.any(), function(req, res){
console.log(req.files);
var tmp_path = req.files[0].path;
var target_path = 'uploads/' + req.files[0].originalname;
var src = fs.createReadStream(tmp_path);
var dest = fs.createWriteStream(target_path);
src.pipe(dest);
src.on('end', function() { res.send("ok"); });
src.on('error', function(err) { res.send({error: "upload failed"}); });
});
app.get('/info', function(req, res){
console.log(__dirname);
res.send("image upload server: post /upload");
});
app.listen(8080);
console.log('started server on localhost...');
我也尝试过使用upload.single() 方法(通过表单工作),但这需要我不确定如何/是否可以添加到Java 多部分实体对象的字段名称。
我目前得到的是请求上的空 files 数组和请求上的 source 变量 body 包含看起来像图像的原始数据的东西,所以基本上看起来像 multer 不是t 做任何事。我错过了什么?
谢谢!
【问题讨论】:
-
谢谢,@Vlad。一切正常!我只有一个问题:在 localhost 上测试时,服务器保存了 2 个大小相同的文件;如何删除临时文件,只留下最终文件?
标签: java android node.js express multer