Spring WS - statyczny WSDL
W poprzednim rozdziale Spring -WS - Pierwsza aplikacja wygenerowaliśmy WSDL automatycznie przy użyciu konfiguracji Spring WS. W takim przypadku pokażemy, jak udostępnić istniejący WSDL za pomocą Spring WS.
Krok | Opis |
---|---|
1 | Utwórz projekt o nazwie leaveService w pakiecie com.tutorialspoint, jak wyjaśniono w rozdziale Spring WS - Pierwsza aplikacja. |
2 | Utwórz plik WSDL leave.wsdl w podfolderze / WEB-INF / wsdl. |
3 | Zaktualizuj spring-ws-servlet.xml w podfolderze / WEB-INF. Używamy tutaj tagu static-wsdl zamiast dynamicznego-wsdl. |
4 | Ostatnim krokiem jest utworzenie zawartości wszystkich plików źródłowych i konfiguracyjnych oraz wyeksportowanie aplikacji, jak wyjaśniono poniżej. |
/WEB-INF/spring-ws-servlet.xml
<wsdl:definitions xmlns:wsdl = "http://schemas.xmlsoap.org/wsdl/"
xmlns:soap = "http://schemas.xmlsoap.org/wsdl/soap/"
xmlns:schema = "http://tutorialspoint.com/hr/schemas"
xmlns:tns = "http://tutorialspoint.com/hr/definitions"
targetNamespace = "http://tutorialspoint.com/hr/definitions">
<wsdl:types>
<xsd:schema xmlns:xsd = "http://www.w3.org/2001/XMLSchema">
<xsd:import namespace = "http://tutorialspoint.com/hr/schemas"
schemaLocation = "hr.xsd"/>
</xsd:schema>
</wsdl:types>
<wsdl:message name = "LeaveRequest">
<wsdl:part element = "schema:LeaveRequest" name = "LeaveRequest"/>
</wsdl:message>
<wsdl:portType name = "HumanResource">
<wsdl:operation name = "Leave">
<wsdl:input message = "tns:LeaveRequest" name = "LeaveRequest"/>
</wsdl:operation>
</wsdl:portType>
<wsdl:binding name = "HumanResourceBinding" type = "tns:HumanResource">
<soap:binding style = "document"
transport = "http://schemas.xmlsoap.org/soap/http"/>
<wsdl:operation name = "Leave">
<soap:operation soapAction = "http://mycompany.com/RequestLeave"/>
<wsdl:input name = "LeaveRequest">
<soap:body use = "literal"/>
</wsdl:input>
</wsdl:operation>
</wsdl:binding>
<wsdl:service name = "HumanResourceService">
<wsdl:port binding = "tns:HumanResourceBinding" name = "HumanResourcePort">
<soap:address location = "http://localhost:8080/leaveService/"/>
</wsdl:port>
</wsdl:service>
</wsdl:definitions>
/WEB-INF/spring-ws-servlet.xml
<beans xmlns = "http://www.springframework.org/schema/beans"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xmlns:context = "http://www.springframework.org/schema/context"
xmlns:sws = "http://www.springframework.org/schema/web-services"
xsi:schemaLocation = "http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/web-services
http://www.springframework.org/schema/web-services/web-services-2.0.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.0.xsd">
<context:component-scan base-package = "com.tutorialspoint.hr"/>
<sws:annotation-driven/>
<sws:static-wsdl id = "leave" location = "/WEB-INF/wsdl/leave.wsdl"/>
</beans>
Uruchom projekt
Gdy skończymy tworzyć pliki źródłowe i konfiguracyjne, powinniśmy wyeksportować aplikację. Kliknij aplikację prawym przyciskiem myszy, użyj opcji Eksportuj → Plik WAR i zapisz plik leaveService.war w folderze webapps Tomcata.
Teraz uruchom serwer Tomcat i upewnij się, że możemy uzyskać dostęp do innych stron internetowych z folderu webapps przy użyciu standardowej przeglądarki. Spróbuj uzyskać dostęp do adresu URL - http: // localhost: 8080 / leaveService / leave.wsdl, jeśli wszystko jest w porządku z aplikacją internetową Spring, zobaczymy następujący ekran.