木偶-使用表单数据和节点获取的POST请求

时间:2018-11-11 03:43:23

标签: node.js puppeteer form-data node-fetch

我正在尝试发出POST请求以将二进制文件上传到服务器,并且表单数据未正确发送(或根本没有发送)。

我目前将节点获取与puppeteer集成在一起,对于使用{"Content-Type": "application/json"}的POST或GET请求来说效果很好。

这是我的代码:

const FormData = require("form-data");
const fetch = require("node-fetch");
const fs = require("fs");

upload(pkgUrl) {
  return new Promise(async (resolve, reject) => {

    const token = ...
    const url = ...

    const stats = fs.statSync(pkgUrl);
    const fileSizeInBytes = stats.size;
    console.log("fileSizeInBytes " + fileSizeInBytes); // Prints a valid size

    const form = new FormData();
    form.append("version", "1.0");
    form.append("appFile", fs.createReadStream(pkgUrl));
    form.append("minFirmwareVersion", 8164134);
    form.append("newPackage", true);

    let headers = form.getHeaders(); 
    headers["csrf-token"] = token;

    const response = await this._makeHTTPRequest(url, "POST", headers, form);

    (...)
  });
}

_makeHTTPRequest(url, method = "GET", headers = null, body = null, parse = true) {
  return new Promise(async (resolve, reject) => {
    try {
      const response = await this._page.evaluate(async (url, method, headers, body, parse) => {
        let request = {
          method: method,
          credentials: "include"
        };

        if (headers) {
          request["headers"] = headers;
        }

        if (body) {
          request["body"] = body;
        }

        // Make request
        const fetchResponse = await fetch(url, request);

        // Return parsed (object) or plain-text response
        return parse ? await fetchResponse.json() : await fetchResponse.text();
      }, url, method, headers, body, parse);

      resolve(response);
    } catch (error) {
      reject(error);
    }
  });
}

这是发送表单数据的方式:
enter image description here

这是发送方式:
enter image description here

另外,要发送的内容长度只有15个字节,应该在2mb左右。

我是否正确使用表单数据和节点获取?

谢谢!

0 个答案:

没有答案
相关问题