Problem
Hier ist die Spring JAX-WS-Konfigurationsdatei …
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:ws="http://jax-ws.dev.java.net/spring/core"
xmlns:wss="http://jax-ws.dev.java.net/spring/servlet"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
http://jax-ws.dev.java.net/spring/core
http://jax-ws.dev.java.net/spring/core.xsd
http://jax-ws.dev.java.net/spring/servlet
http://jax-ws.dev.java.net/spring/servlet.xsd"
>
<wss:binding url="/ws/OrderWs">
<wss:service>
<ws:service bean="#orderWs"/>
</wss:service>
</wss:binding>
<!-- this bean implements web service methods -->
<bean id="#orderWs" class="com.mkyong.order.ws.OrderWS">
<property name="orderBo" ref="OrderBo"/>
</bean>
</beans>
Während des Serverstarts wird folgende Fehlermeldung angezeigt:
Caused by: org.xml.sax.SAXParseException: cvc-datatype-valid.1.2.1:
'#orderWs' is not a valid value for 'NCName'.
Lösung
Die Fehlermeldung des SAX-Parsers ist irreführend, es sollte "** # orderWs" nicht vorhanden sein. Ein sehr häufiger Tippfehler, ein zusätzliches "#" in der Bean-Konfiguration von Spring. Die korrekte Konfiguration sollte folgendermaßen aussehen:
<wss:binding url="/ws/OrderWs">
<wss:service>
<ws:service bean="#orderWs"/>
</wss:service>
</wss:binding>
<!-- orderWs, not #orderWs -->
<bean id="orderWs" class="com.mkyong.order.ws.OrderWS">
<property name="orderBo" ref="OrderBo"/>
</bean>