我正在使用Rest-Assured根据模式编写XML验证器。但是,我在处理引用其他XSD的XSD时遇到问题,因为我使用GET从URL检索原始XSD。
我一直在尝试实现自己的解析来将XSD(字符串)合并到一个XSD(字符串)中,但它正在变成一个递归的怪物,而且非常低效/困难。要查看算法,请查看帖子的结尾。
我有两个问题: 1)我的问题是我使用GET来检索XSD,因此它不在命名空间内。有没有办法获取所有引用的XSD并使用Rest-Assured合并它们?我不知道如何解决这个问题。
2)一般来说,是否有更好的方法来处理包含?正如您所看到的,我的算法非常昂贵且过于复杂(尤其是ref属性),而且如果我更改测试用例,我确信某些内容会很容易破解。
到目前为止,我的算法(伪代码以避免复杂性)如下所示:
boolean xmlValid(String xmlAddress, String xsdAddress){
LinkedList XSDList = new LinkedList;
XSDList.add(xsdAddress);
xsdString = getExternalXSDStrings(XSDList);
try{ //No PseudoCode here
RestAssured.expect().
statusCode(200).
body(
RestAssuredMatchers.matchesXsd(xsdString)).
when().
get(xmlAddress);
}catch Exceptions{...}
}
String getExternalXSDStrings(LinkedList xsdReferences, String prevString){
LinkedList recursiveXSDReferences = new LinkedList();
for(xsdRef:xsdReferences){
xsdAddress = "http://..." + xsdRef;
Open InputStream From URL;
while(inputLine != null){
if(prologFlag) //Do Nothing, this is to avoid multiple prologs ;
else if(includeFlag){
if(refFlag) Note Reference;
else recursiveXSDReferences.add(includeReference);
}else if(refFlag){
referenceDefinition = Extract Reference Element Definition;
xsdString = xsdString + referenceDefinition;
}else{
xsdString = xsdString + inputLine;
}
}
Close input stream;
}
xsdString = prevString + xsdString;
if(xsdReferences.length > 0) return getExternalXSDStrings(recursiveXSDReferences , xsdString);
else return xsdString;
}
非常感谢您提前!
答案 0 :(得分:0)
也许可以在详细配置中使用XmlConfig。这使您可以访问配置功能和命名空间等。例如,如果要禁用外部DTD的加载,您可以这样做:
given().config(RestAssured.config().xmlConfig(xmlConfig().disableLoadingOfExternalDtd())). ..
所以也许您可以查看“disableLoadingOfExternalDtd”方法,看看它是如何实现的,以获得一些提示。