0

我需要向我的项目的 api 发送 xml 请求。但是出于安全原因,我不能在我的程序中直接编写 xml。所以我决定使用 jsonix 将 JSON 编组为 xml,并解组请求的响应。但我有一些问题。

这是我的xml:

<?xml version = '1.0' encoding='UTF-8'?>
<api>
    <authentication>
        <login>MyLogin</login>
        <password>MyPassword</password>
    </authentication>
    <command>
        <myfunction>
            <name>test</name>
        </myfunction>
     </command>
</api>

有了这个,我用 jsonix-schema-compiler 模块生成了映射:

var Search_Module_Factory = function () {
	var Search = {
		name: "Search",
		typeInfos: [{
			localName: "Api.Command",
			typeName: null,
			propertyInfos: [{
				name: "myFunction",
				required: true,
				elementName: {
					localPart: "myfunction"
				},
				typeInfo: ".Api.Command.MyFunction"
			}]
		}, {
			localName: "Api.Authentication",
			typeName: null,
			propertyInfos: [{
				name: "login",
				required: true,
				elementName: {
					localPart: "login"
				}
			}, {
				name: "password",
				required: true,
				elementName: {
					localPart: "password"
				}
			}]
		}, {
			localName: "Api.Command.MyFunction",
			typeName: null,
			propertyInfos: [{
				name: "name",
				required: true,
				elementName: {
					localPart: "name"
				}
			}]
		}, {
			localName: "Api",
			typeName: null,
			propertyInfos: [{
				name: "authentication",
				required: true,
				elementName: {
					localPart: "authentication"
				},
				typeInfo: ".Api.Authentication"
			}, {
				name: "command",
				required: true,
				elementName: {
					localPart: "command"
				},
				typeInfo: ".Api.Command"
			}]
		}],
		elementInfos: [{
			typeInfo: ".Api",
			elementName: {
				localPart: "api"
			}
		}]
	};
	return {
		Search: Search
	};
};
if (typeof define === "function" && define.amd) {
	define([], Search_Module_Factory);
}
else {
	var Search_Module = Search_Module_Factory();
	if (typeof module !== "undefined" && module.exports) {
		module.exports.Search = Search_Module.Search;
	}
	else {
		var Search = Search_Module.Search;
	}
}

在我的主代码中,我正在编组这样的 xml 请求:

var Search = require("./mappings/Search").Search;
var context = new Jsonix.Context([ Search]);
var marshaller = context.createMarshaller();

var originalJS = {
			"api": {
				"authentication": {
					"login" :"mylogin",
					"password": "mypassword",
				},
				"command":{
					"myfunction":{
						"name": "test"
					}
				},
			}
		};
var marshalledXML = marshaller.marshalString(originalJS);
console.log(marshalledXML);

在 console.log() 中,而不是向我展示这样的东西,这是我想要的结果:

<api><authentication><login>mylogin</login><password>mypassword</password></authentication><command><myfunction><name>test</name></myfunction></command></api>

它返回的是这样的:

<api><authentication><login>mylogin</login><password>mypassword</password></authentication><command/></api>

tag 命令总是空的,我不明白我做错了什么。感谢您的帮助

4

0 回答 0