首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >400多部分文件上传的不良请求

400多部分文件上传的不良请求
EN

Stack Overflow用户
提问于 2016-10-03 14:02:22
回答 1查看 1.8K关注 0票数 1

我正试图上传一个图片到PushBullet API的改造。

上传-请求之后,我启动了多部分上传。

经过改造,我得到了以下错误:

代码语言:javascript
运行
复制
{"error":{"code":"invalid_request","type":"invalid_request","message":"Invalid multipart body.","cat":"o(^・x・^)o"},"error_code":"invalid_request"}

这个问题只发生在我的java代码中,而不是在中。

代码语言:javascript
运行
复制
# PAW generated Request
POST /upload-legacy/bcSWXnBjNIwpkej7CxfIHFz0ugXO6yhf HTTP/1.1
Content-Type: multipart/form-data; charset=utf-8; boundary=__X_PAW_BOUNDARY__
Host: upload.pushbullet.com
Connection: close
User-Agent: Paw/3.0.12 (Macintosh; OS X/10.11.6) GCDHTTPRequest
Content-Length: 34508

--__X_PAW_BOUNDARY__
Content-Disposition: form-data; name="file"; filename="cat.jpg"
Content-Type: image/jpeg

...

# Retrofit generated Request
POST https://upload.pushbullet.com/upload-legacy/ZZ4fLcqt2WFQmlbKTDlgcYXtB3KiCs3M http/1.1
Content-Type: multipart/form-data; charset=utf-8
Content-Length: 2012
Content-Disposition: form-data; name="file"; filename="1475501429665_motion_detected.jpg"
Content-Type: image/jpeg; charset=utf-8
Content-Length: 1772

...

我认为最重要的区别是Part中的Part。我找到了这个问题,但这意味着PushBullet API与HTTP不兼容?

任何帮助都将不胜感激。

EN

Stack Overflow用户

发布于 2021-12-19 19:50:36

在基于JavaScript的Google脚本中,我也遇到了同样的问题,但我希望我的解决方案能够帮助其他经历过这个问题的人。我在这里使用了TANAIKE构建多部分请求的方法:https://gist.github.com/tanaikech/d595d30a592979bbf0c692d1193d260c

我成功上传JPEG的最终结果如下所示:

代码语言:javascript
运行
复制
    // https://docs.pushbullet.com/v8/#upload-request
    // Assuming var picResponseJSON is your JSON results from successful upload-request
    var uploadJSON = {
      awsaccesskeyid: picResponseJSON.data.awsaccesskeyid,
      acl: picResponseJSON.data.acl,
      key: picResponseJSON.data.key,
      signature: picResponseJSON.data.signature,
      policy: picResponseJSON.data.policy,
      "content-type": picResponseJSON.data["content-type"],
    };

    // https://gist.github.com/tanaikech/d595d30a592979bbf0c692d1193d260c
    var boundary = "xxxxxxxxxx";
    var data = "";
    for (var i in uploadJSON) {
      data += "--" + boundary + "\r\n";
      data +=
        'Content-Disposition: form-data; name="' +
        i +
        '"; \r\n\r\n' +
        uploadJSON[i] +
        "\r\n";
    }
    data += "--" + boundary + "\r\n";
    data +=
      'Content-Disposition: form-data; name="file"; filename="' +
      fileTitle +
      '"\r\n';
    data += "Content-Type:" + mimeType + "\r\n\r\n";
    var payload = Utilities.newBlob(data)
      .getBytes()
      .concat(DriveApp.getFileById(fileID).getBlob().getBytes())
      .concat(Utilities.newBlob("\r\n--" + boundary + "--").getBytes());
    var options3 = {
      method: "post",
      contentType: "multipart/form-data; boundary=" + boundary,
      payload: payload,
      muteHttpExceptions: true,
    };

    // Send request
    var uploadResponse = UrlFetchApp.fetch(picResponseJSON.upload_url, options3);

    // Confirm it's successful
    if (uploadResponse.getResponseCode() == 204) {
      console.log("Success! File: " + picResponseJSON.file_url);
    }

请注意,有效负载中的Blob函数是Google脚本的一部分,因此可以根据您的语言进行相应的修改。

票数 0
EN
查看全部 1 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/39833504

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档