POST请求期间正在修改对象的结构

时间:2018-08-08 11:37:35

标签: node.js express needle.js

所以我使用以下对象作为主体使用needle发送了发布请求:

{ time: 1533725993910,
  rconPort: 52940,
  rconPassword: 'muqrxllv',
  serverPort: 38950,
  unique: 795571399,
  publicIP: 'localhost',
  mods:
   [ { modName: 'clusterio_1.0.0.zip',
       hash: '341feb6c60918c83f7f3a6a14a4a308aef18dda6' },
     { modName: 'clusterio_1.13.1.zip',
       hash: '6124bb9d3896b030fafbef07c971314f4640759f' },
     { modName: 'clusterio_1.13.0.zip',
       hash: '3dde5199f63d87e3e6ea6ef7f522e0df5842dee4' },
     { modName: 'hotpatch-multimod_1.1.4.zip',
       hash: '0a780e23c42452bd51ecc5ce808b65842e77dc85' },
     { modName: 'creative-mode_0.0.1.zip',
       hash: '9af437c10d3f39f1f3ffb57c942c3a51d3786f0f' },
     { modName: 'clusterio_1.12.0.zip',
       hash: '959c82380cad1a6f039de401a98dd70e13ca2224' } ],
  instanceName: 'test',
  playerCount: '0' }

在Express处理程序中console.log(req.body)出现

{ time: '1533722833600',
  rconPort: '52940',
  rconPassword: 'muqrxllv',
  serverPort: '38950',
  unique: '795571399',
  publicIP: 'localhost',
  mods: [ { modName: [Array], hash: [Array] } ],
  instanceName: 'test',
  playerCount: '0',
  mac: '00-FF-8C-0F-21-F0' }

仔细检查后发现,“ mods”字段现在看起来像这样:

"mods":[{
  "modName":[
    "clusterio_1.0.0.zip",
    "clusterio_1.13.0.zip",
    "clusterio_1.13.1.zip",
    "hotpatch-multimod_1.1.4.zip",
    "creative-mode_0.0.1.zip",
    "clusterio_1.12.0.zip"
  ],"hash":[
    "341feb6c60918c83f7f3a6a14a4a308aef18dda6",
    "3dde5199f63d87e3e6ea6ef7f522e0df5842dee4",
    "6124bb9d3896b030fafbef07c971314f4640759f",
    "0a780e23c42452bd51ecc5ce808b65842e77dc85",
    "9af437c10d3f39f1f3ffb57c942c3a51d3786f0f",
    "959c82380cad1a6f039de401a98dd70e13ca2224"
]}]

我用于在服务器端记录数据

var app = express();
app.use(bodyParser.json());
app.use((req,res,next) => {
    if(req.originalUrl == "/api/getID"){
        console.log(req.body)
    }
    next()
});

我在客户端

console.log(payload);
needle.post('localhost:8080/api/getID', payload, needleOptionsWithTokenAuthHeader, function (err, response, body) {

起初我怀疑这是中间件的问题,但是由于我在所有中间件都加载之前就进行记录,因此我对此不太确定。

我从未经历过这样的事情,我们将不胜感激。

1 个答案:

答案 0 :(得分:0)

您是否尝试过使用功能JSON.stringifydoc)? 用表格格式化POST请求可能很棘手。

要发送类似{a:1, b:{c:2, d:[3, 4]}, e:[5,6]}的对象,您必须格式化参数以适合数组关联,因此参数将如下所示:

a=1
b[c]=2
b[d][0]=3
b[d][1]=4
e[0]=5
e[1]=6

要填充非关联数组,可以尝试使用e[]=7表示法。