Servicios Web ligeros Alternativas al protocolo SOAP para
Servicios Web ligeros Alternativas al protocolo SOAP para la creación de servicios distribuidos Noé Fernández Iglesias
Introducción Popularización de los Servicios Web n n HTTP XML Protocolo SOAP
SOAP Protocolo de referencia para la creación de SW n Mensajes XML sobre HTTP n Fichero de definición WSDL n UDDI
SOAP Principales críticas al protocolo n Complejo n Mensajes XML Sobrecarga de red n WSDL n Demasiado pesado para pequeños dispositivos
Alternativas a SOAP Caucho Technology n n Hessian Burlap Spring framework n HTTP invoker
Hessian Protocolo binario sobre HTTP Ligero Los servicios son desplegados como servlets No necesita fichero de descripción (WSDL, IDL, …) Usa un mecanismo propio de serialización Implementado en varias plataformas n Java, C++, C#, PHP, Ruby, Python
Hessian Creación de un servicio con Hessian: n n Creación de una interfaz Java a modo de API pública. Creación de un cliente del servicio mediante Hessian. Proxy. Factory. Creación de la clase de implementación del servicio. Despliegue y configuración del servicio en un contenedor de servlets.
Hessian Creación de una interfaz Java a modo de API pública public interface HWService { public String hello. World(); }
Hessian Creación de un cliente del servicio mediante Hessian. Proxy. Factory public class Basic. Client { public static void main(String []args) throws Exception { String url = "http: //localhost/hello. World"; Hessian. Proxy. Factory factory = new Hessian. Proxy. Factory(); HWService service = (HWService) factory. create(HWService. class, url); System. out. println("Hello: " + basic. hello()); } }
Hessian Creación de la clase de implementación del servicio public class My. Service implements HWService { public String hello() { return "Hello, world"; } }
Hessian Despliegue y configuración del servicio en un contenedor de servlets <web-app> <servlet-name>hello</servlet-name> <servlet-class>com. framework. Hessian. Servlet</servlet-class> <init-param> <param-name>home-class</param-name> <param-value>My. Service</param-value> </init-param> <param-name>home-api</param-name> <param-value>HWService</param-value> </init-param> </servlet> <servlet-mapping> <url-pattern>/hello. World</url-pattern> <servlet-name>hello</servlet-name> </servlet-mapping> </web-app>
Burlap Versión XML de Hessian Mensajes SML sobre HTTP Los servicios son desplegados como servlets No necesita fichero de descripción (WSDL, IDL, …) Usa un mecanismo propio de serialización Implementado actualmente sólo en Java
Burlap Creación de un servicio con Burlap: n n Creación de una interfaz Java a modo de API pública. Creación de un cliente del servicio mediante Burlap. Proxy. Factory. Creación de la clase de implementación del servicio. Despliegue y configuración del servicio en un contenedor de servlets.
HTTP invoker Solución del framework Spring para el desarrollo de servicios remotos. Funciona sobre HTTP Utiliza la serialización de Java Sencilla implementación y despliegue de servicios (pasos similares a Hessian y Burlap)
HTTP invoker Creación de un servicio con HTTP invoker: n n Creación de una interfaz del servicio e implementación de la misma. Exportación del servicio mediante la definición de un bean de Spring. Despliegue del servicio en un contenedor de servlets. Creación del bean de Spring para el cliente.
HTTP invoker Exportación del servicio mediante la definición de un bean de Spring : <bean name="/My. Service" class="org. springframework. remoting. httpinvoker. Http. Invoker. Service. Exporter"> <property name="service"> <ref bean="my. Service"/> </property> <property name="service. Interface"> <value>com. http. Invoker. example. My. Service</value> </property> </bean>
HTTP invoker Despliegue del servicio en un contenedor de servlets : <servlet> <servlet-name>my. Service. Http. Invoker</servlet-name> <servlet-class> org. springframework. web. servlet. Dispatcher. Servlet </servlet-class> <load-on-startup>3</load-on-startup> </servlet> <servlet-mapping> <servlet-name>my. Service. Http. Invoker</servlet-name> <url-pattern>/remoting/*</url-pattern> </servlet-mapping>
HTTP invoker Creación del bean de Spring para el cliente : <bean id="service" class="org. springframework. remoting. httpinvoker. Http. Invoker. Proxy. Factory. Bean"> <property name="service. Url"> <value>http: //localhost/remoting/My. Service</value> </property> <property name="service. Interface"> <value>com. http. Invoker. example. My. Service</value> </property> <property name="http. Invoker. Request. Executor"> <bean class= "org. springframework. remoting. httpinvoker. Commons. Http. Invoker. Request. Executor"/> </property> </bean>
HTTP invoker Invocación del servicio: My. Service service = (My. Service)context. get. Bean("service"); service. hello();
Conclusiones ¿Cuándo usar cada protocolo? n Tenemos control sobre el servicio y el cliente Hessian, Burlap, HTTP invoker Poco ancho de banda: Hessian, Burlap n Clientes de diversas plataformas Hessian n Aplicaciones complejas, diversos protocolos, funcionalidad prima sobre la velocidad SOAP
- Slides: 20