Как я могу использовать альтернативный парсер XML с Weblogic и Spring-ws? - PullRequest
2 голосов
/ 11 января 2012

Я использую WebServiceGatewaySupport для реализации SOAP-клиента.В рамках этих вызовов SOAP я реализую свой собственный org.springframework.ws.client.core.SourceExtractor для сопоставления возвращенного XML с объектами моего домена.

Мне кажется, что DOMSource объект отправляется в SourceExtractor, поэтому я пытаюсьиспользовать DOM API и реализацию, встроенную в мой сервер приложений (который является древним Weblogic 10.0 MP2).Реализация, однако, кажется неполной, о чем свидетельствует следующий след.

java.lang.AssertionError: UNIMPLEMENTED
    at weblogic.xml.domimpl.NodeImpl.getTextContent(NodeImpl.java:198)
    at com.cinfin.ecm.security.CICUserSourceExtractor.extractData(CICUserSourceExtractor.java:22)
    at com.cinfin.ecm.security.CICUserSourceExtractor.extractData(CICUserSourceExtractor.java:1)
    at org.springframework.ws.client.core.WebServiceTemplate$SourceExtractorMessageExtractor.extractData(WebServiceTemplate.java:807)
    at org.springframework.ws.client.core.WebServiceTemplate.doSendAndReceive(WebServiceTemplate.java:596)
    at org.springframework.ws.client.core.WebServiceTemplate.sendAndReceive(WebServiceTemplate.java:537)
    at org.springframework.ws.client.core.WebServiceTemplate.doSendAndReceive(WebServiceTemplate.java:492)
    at org.springframework.ws.client.core.WebServiceTemplate.sendSourceAndReceive(WebServiceTemplate.java:479)
    at org.springframework.ws.client.core.WebServiceTemplate.sendSourceAndReceive(WebServiceTemplate.java:470)
    at org.springframework.ws.client.core.WebServiceTemplate.sendSourceAndReceive(WebServiceTemplate.java:458)
    at com.cinfin.ecm.security.CICSecurityService.getRolesForUser(CICSecurityService.java:32)
    at com.cinfin.ecm.security.CICSecurityServiceTest.testGetRolesForUser(CICSecurityServiceTest.java:29)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:592)
    at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:45)
    at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:15)
    at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:42)
    at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:20)
    at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:28)
    at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:263)
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:68)
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:47)
    at org.junit.runners.ParentRunner$3.run(ParentRunner.java:231)
    at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:60)
    at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:229)
    at org.junit.runners.ParentRunner.access$000(ParentRunner.java:50)
    at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:222)
    at org.junit.runners.ParentRunner.run(ParentRunner.java:300)
    at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:50)
    at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:467)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:683)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:390)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:197)

Мой первый вопрос, очевидно, как мне получить текстовое значение узлов в этом DOMSource?Могу ли я использовать Spring / Spring-ws, чтобы заменить синтаксический анализатор XML, используемый для удаления исходного кода?Во-вторых, эта реализация на правильном пути?Есть ли более простой, более весенний способ сделать то, что я делаю?

1 Ответ

2 голосов
/ 13 января 2012

В итоге проблема заключалась в том, что Bea / Oracle вместо реализации стандартного интерфейса DOM использует собственный закрытый API.Во время отладки моего кода, пытаясь понять, куда вставить другой анализатор XML, я заметил, что текстовые данные узла действительно извлекаются.Он был в защищенной переменной-члене String data в экземпляре класса weblogic.xml.domimpl.TextImpl.Так как источник не опубликован, я не мог просто посмотреть в классе, чтобы увидеть, как к этой переменной обращались, поэтому я просмотрел имена методов для чего-то, что выглядело близко.Я нашел метод с именем getData().

Вот что моя реализация пыталась сделать раньше (что может или не может быть правильным на основе интерфейса DOM):

public T extractData(Source source) throws IOException {
    Node rootNode = ((DOMSource)source)
    NodeList nodes = rootNode.getChildElements();
    for (int i = 0; i < nodes.getLength(); i++) {
        String nodeText = nodes.item(i).getTextContent();
        /* Remainder of loop and method elided */
    }
}

Что сейчасРабота:

public T extractData(Source source) throws IOException {
    Node rootNode = ((DOMSource)source)
    NodeList nodes = rootNode.getChildElements();
    for (int i = 0; i < nodes.getLength(); i++) {
        TextImpl nodeTextImpl = (TextImpl) nodes.item(i).getFirstChild();
        String nodeText = nodeTextImpl.getData();
        /* Remainder of loop and method elided */
    }
}

Я был бы признателен за комментарии от тех, кто более знаком с API Java DOM, особенно комментарии, которые исправят мое использование get*() методов, доступных в org.w3c.dom.Node.

...