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.