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>