【问题标题】:Upload image with Java MultipartEntity to Node.js server using express and multer使用 express 和 multer 将带有 Java MultipartEntity 的图像上传到 Node.js 服务器
【发布时间】: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


【解决方案1】:

我最终使用了 Android Ion 库 - https://github.com/koush/ion

Java 代码:

Ion.with(context)
            .load("http://" + SERVER + ":8080/upload")
            .progressDialog(pd)
            .setMultipartParameter("name", "source")
            .setMultipartFile("image", "image/jpeg", new File(imgPath))
            .asJsonObject()
            .setCallback(new FutureCallback<JsonObject>() {
                @Override
                public void onCompleted(Exception e, JsonObject result) {

                    //do stuff with result
                }
            });

服务器代码保持不变。

【讨论】:

  • 谢谢。经过数小时的搜索后得到了这个。老实说,没有其他工作。
  • 你好,我尝试使用它,但我在服务器上的 req.files 对象中没有得到 req.files[0].path,你能帮我解决这个问题吗?
  • @Vlad 有没有办法在单个请求中发送多个文件?
  • 第一。拯救了我的一天。
猜你喜欢
  • 1970-01-01
  • 2016-09-25
  • 1970-01-01
  • 2017-05-22
  • 2015-05-02
  • 2021-02-10
  • 2020-12-25
  • 2020-10-10
  • 2021-05-03
相关资源
最近更新 更多