Soap на node анализирует json на xml неправильно
Используя модуль Soap в Nodejs (через loopback-connector-soap), я пытаюсь преобразовать json в xml для моего запроса на мыло, но у меня есть несколько проблем...
Что это такое:
<ns:UserDefinedFields>
<ns:UserDefinedField>
<ns:displayName>Campaign?</ns:displayName>
<ns:fieldValue>Yes</ns:fieldValue>
</ns:UserDefinedField>
</ns:UserDefinedFields>
<ns:UserDefinedFields>
<ns:UserDefinedField>
<ns:displayName>Anticipated Use</ns:displayName>
<ns:fieldValue>6</ns:fieldValue>
</ns:UserDefinedField>
Что это должно быть:
<ns:UserDefinedFields>
<ns:UserDefinedField>
<base:displayName>Campaign?</base:displayName>
<base:fieldValue>Yes</base:fieldValue>
</ns:UserDefinedField>
<ns:UserDefinedField>
<base:displayName>Anticipated Use</base:displayName>
<base:fieldValue>6</base:fieldValue>
</ns:UserDefinedField>
</ns:UserDefinedFields>
- Должен быть только один
<ns:UserDefinedFields>
- И должен быть
<base:fieldValue>
вместо <ns:fieldValue>
Любые советы были бы очень полезны! Спасибо!
XML:
{
...
"UserDefinedFields": [
{
"displayName": "Campaign?",
"fieldValue": "Yes"
},
{
"displayName": "Anticipated Use",
"fieldValue": 6
}
]
...
}
XSD:
...
<xs:element name="UserDefinedFields" minOccurs="0">
<xs:complexType>
<xs:sequence>
<xs:element name="UserDefinedField" type="base:UserDefinedFieldType" minOccurs="0" maxOccurs="15"/>
</xs:sequence>
</xs:complexType>
</xs:element>
...
Ответы
Ответ 1
Чтобы иметь дело с пространством имен, пропустите ignoredNamespaces параметры soap.createClient
.
{
"ignoredNamespaces": {
namespaces: ['ns']
},
}
И затем добавьте пространство имен вручную. Это уродливо, но оно работает.
Чтобы иметь дело с несколькими UserDefinedFields
, он должен выглядеть следующим образом:
{
. . .
DomainRegistration['ns:UserDefinedFields']['ns:UserDefinedField'][0] : {
"base:displayName": "Campaign?",
"base:fieldValue": "Yes"
},
DomainRegistration['ns:UserDefinedFields']['ns:UserDefinedField'][1] : {
"base:displayName": "Anticipated Use",
"base:fieldValue": 6
}
. . .
}
Или проще:
{
ouside: {
insideA: [
'one',
'two',
]
insideB: [
{'one':'ONE'},
{'two':'TWO'}
]
}
}
//will create:
<outside>
<insideA>
<one />
<two />
</insideA>
<insideB>
<one>ONE</one>
</insideB>
<insideB>
<two>TWO</two>
</insideB>
</outside>