Servicios Web

Anuncio
Servicios Web
Capítulo 6:
Tecnología Básica de los Servicios Web
Pedro Álvarez
alvaper@unizar.es
José Ángel Bañares
banares@unizar.es
http://diis.unizar.es/PostWeb/
Departamento de Informática e Ingeniería de Sistemas
Índice - Capítulo 6
o
o
o
o
Infraestructura mínima para Servicios Web
SOAP: Simple Access Protocol
Þ Objetivos de SOAP
Þ Estructura y contenidos de un mensaje SOAP
Þ Mapeo de SOAP a un protocolo de transporte
Þ RPC sobre SOAP
Þ SOAP asíncrono
Þ Ejemplo SOAP y Java
WSDL:Web Service Description Language
Þ Objetivos de WSDL
Þ Estructura de una interface WSDL
Þ Implicaciones del modelo WSDL
Þ Utilización de WSDL
UDDI: Universal Description Discovery and Integration
Þ Objetivos de UDDI
Þ Estructuras de dato UDDI
Þ Descripción del API UDDI
Þ Pasos para publicar un servicio Web
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
2
Infraestructura mínima de Servicios Web
o
Para abordar el problema de la invocación de Servicios Web precisamos:
Þ Una sintaxis común para todas las especificaciones:
Þ Un mecanismo de interacción entre lugares remotos.
• La especificación de este mecanismo requiere
1.
2.
3.
Un formato de datos común para los mensajes que se intercambian
Un acuerdo o norma para soportar formas de interacción específicas (p.e.
mensajes o RPC)
Un conjunto de mapeos de mensajes en un protocolo de transporte
u
En el contexto de los servicios Web se pueden usar diferentes
protocolos de transporte: TCP/IP, HTTP para hacer tunneling, SMTP
(e-mail) si se quiere mensajes asíncronos.
s
•
Por lo tanto el mecanismo debe ser lo suficientemente general para trabajar con
diferentes protocolos de transporte.
El mecanismo de interacción debe permitir que las aplicaciones estén
poco acopladas
•
•
Por esta razón la unidad de comunicación básica será el mensaje
Sin embargo, se pueden permitir también interacciones al estilo RPC, por
ejemplo, cuando las dos aplicaciones fueron diseñadas originalmente sobre
middlewares basados en RPC.
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
3
Infraestructura mínima de Servicios Web
o
SOAP
Þ Lo servicios pueden intercambiar mensajes por medio de
convenciones estandarizados para:
• Transformar una invocación en un mensaje XML
• Intercambiar mensajes
• Recuperar la invocación real al servicio desde un mensaje en
XML
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
4
Infraestructura mínima de Servicios Web
o
WDSL: Descripción de los servicios (especialmente sus interfaces) de
forma estándar
Þ Cumple el papel de los IDLs en middleware convencionales,
añadiendo lo necesario para tratar con la falta de un middleware
centralizado que gestiona transporte y redirección de mensajes.
Þ El interface se especifica cada método, con sus parámetros de
entrada y salida.
• Si el estilo de interacción es RPC, estos mensajes llevan los
parámetros de entrada y salida del procedimiento invocado.
• Un fichero WSDL se puede compilar para el lenguaje de
programación apropiado y generar los stubs y capas intermedias
necesarias para hacer las llamadas Web de forma transparente.
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
5
Infraestructura mínima de Servicios Web
proveedor servicio
cliente servicio
objeto aplicación
(cliente)
objeto aplicación
(proveedor
servicio)
middleware
basado en SOAP
middleware
basado en SOAP
mensajes SOAP
intercambiados sobre
HTTP, SMTP, u otro
transporte
convierte llamadas de procedimiento
a/de mensajes XML enviados a través
de HTTP u otros protocolos.
Copyright Springer Verlag Berlin Heidelberg 2004
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
6
Infraestructura mínima de Servicios Web
<operation name="orderGoods">
<input message = "OrderMsg"/>
</operation>
Copyright Springer Verlag Berlin Heidelberg 2004
WSDL del
proveedor del
servicio
compilador WSDL
(lado cliente)
La principal diferencia con
middleware convencionales es
la ausencia de una plataforma
middleware común.
compilador WSDL
(lado servidor)
cliente servicio
proveedor servicio
Objeto de la
aplicación
(cliente)
Objeto de la
aplicación
(proveedor servicio)
stub
skeleton
middleware
basado en SOAP
middleware
basado en SOAP
mensajes SOAP
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
7
Infraestructura mínima de Servicios Web
IDL del
proveedor
de servicios
interface Purchasing {
float getQuote ( in long productId);
float purchaseGoods (in long productId, in long
quantity)
}
compilador IDL
(lado cliente)
compilador IDL
(lado servidor)
objeto de la
aplicación
(cliente)
objeto de la
aplicación
(proveedor servicio)
stub
skeleton
Object Request Broker
Copyright Springer Verlag Berlin Heidelberg 2004
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
8
Infraestructura mínima de Servicios Web
Cliente servicio
Proveedor de servicio
objeto aplicación
(cliente)
objeto aplicación
(proveedor
servicio)
stub
skeleton
middleware
basado en SOAP
middleware
basado en SOAP
mensajes SOAP
mensajes SOAP
(para buscar servicios)
Sólo nos falta un servicio de nombres
y directorio:
•Interfaces y URI en el que están
disponibles los servicios
mensajes SOAP
(para publicar descripciones de servicios)
middleware basado en SOAP
descripciones de servicio
Copyright Springer Verlag Berlin Heidelberg 2004
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
registro UDDI
9
SOAP: Simple Access protocol
o
o
Breve historia
Þ El W3C comienza a trabajar con SOAP en 1999
Þ La primera versión 1.0 se basa enteramente en HTTP
Þ La siguiente revisión 1.1 (Mayo 2000) se reconvierte en un
transporte genérico de información sobre una variedad de protocolos
de transporte.
Þ Mayo de 2003, la nueva versión 1.2 clarifica y añade semántica
adicional sobre SOAP 1.1 en términos de mapeos a protocolos y
codificación XML. (Especificación en fase de revisión)
Objetivos de SOAP: Como organizar la información utilizando XML de
forma estructurada y tipada de forma que pueda ser intercambiada entre
iguales.
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
10
SOAP especifica
o
En concreto SOAP especifica:
Þ Un formato de mensaje para comunicaciones en una dirección,
describiendo como se organiza la información en un documento
XML.
Þ Un conjunto de normas para implementar interacciones al estilo
RPC mediante mensajes SOAP, definiendo como los clientes pueden
invocar un procedimiento remoto enviando un mensaje SOAP y
como los servicios pueden replicar enviando otro mensaje al cliente.
Þ Un conjunto de reglas que cualquier entidad que procesa un mensaje
SOAP debe seguir. Definen que elementos debería leer y
comprender, y las acciones que deberían realizar sino entienden el
contenido.
Þ Una descripción de cómo su mensaje SOAP se debería transportar
sobre HTTP y SMTP.
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
11
SOAP
o
o
Como protocolo de comunicación,
Þ SOAP no tiene estado
Þ Es una comunicación en una dirección.
Þ Ignora la semántica de los mensajes intercambiados.
Þ Soporta interacciones entre aplicaciones poco acopladas mediante
intercambio de mensajes “ASINCRONOS” y en “UNA
DIRECCION”.
Cualquier complejidad posterior como mensajes síncronos y
bidireccionales, o interacciones al estilo RPC requieren que SOAP se
combine con un protocolo subyacente (o middleware) que tenga
propiedades adicionales:
Þ Por ejemplo un protocolo de transporte síncrono como HTTP debería
ser usado para transportar los dos mensajes: uno en la petición
HTTP, y otro en la respuesta
Þ Como opuesto a una comunicación asíncrona con STMP.
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
12
Estructura y contenidos
de un mensaje SOAP
o
o
o
o
o
o
SOAP se basa en intercambio de mensajes
Los mensajes son como sobres donde la
aplicación encierra los datos que se van a
enviar
Un mensaje tiene dos partes:
Þ Header (cabecera): que se puede
dividir en bloques
Þ Body (cuerpo): que se puede dividir en
bloques
SOAP no establece lo que hay que hacer con
la cabecera y el cuerpo, solo establece que la
cabecera es opcional.
La cabecera es para el nivel de
infraestructura.
El cuerpo es para el nivel de aplicación.
SOAP Envelope
SOAP header
Header Block
SOAP Body
Body Block
Bloques: Cualquier primer nivel hijo.
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
13
Estructura y contenidos
de un mensaje SOAP
o
o
o
SOAP asume que cada mensaje tiene un remitente (sender) y un
receptor (receiver), y un número arbitrario de intermediarios (llamados
nodos) que procesan el mensaje y redirigen este al receptor.
El núcleo de la información que envía el remitente al receptor está en el
body.
En el header, cualquier otra información para procesado intermedio o
servicios de valor añadido.).
Þ Usos típicos del header son: información de coordinación,
identificadores (p.e., transacciones), información de seguridad (p.e,
certificados)
Þ La necesidad de los intermediarios es obvia si pensamos que el
procedimiento invocado real es parte de una arquitectura de varias
capas.
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
14
Estructura y contenidos
de un mensaje SOAP
o
o
SOAP no establece ninguna estructura posterior en el contenido de las
cabecera o los mensajes.
Pero existen formas comúnmente aceptadas de construir la cabecera y el
cuerpo de los mensajes.
Þ Los aspectos que influyen en como se construyen el body y el
header:
• El estilo de interacción: Estilo RPC, y estilo Documento.
u
Si la interacción es síncrona o asíncrona es ortogonal al estilo de
interacción, y no influye en la estructura.
• Reglas de codificación: Como se representa una estructura o dato
en XML.
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
15
Estructura y contenidos
de un mensaje SOAP: Estilo de interacción
SOAP envelope
SOAP envelope
SOAP body
SOAP body
documento
ordenCompra
-producto
-cantidad
documento
Acknowledgement
-id_de_orden
Estilo de interacción Documento
Copyright Springer Verlag Berlin Heidelberg 2004
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
16
Estructura y contenidos
de un mensaje SOAP: Estilo de interacción
SOAP envelope
SOAP envelope
SOAP body
SOAP body
method name
ordenCompra
method return
input parameter 1
producto
return value
-id_de_orden
input parameter 2
cantidad
Estilo de interacción RPC
Copyright Springer Verlag Berlin Heidelberg 2004
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
17
Estructura y contenidos
de un mensaje SOAP: Reglas de codificación
<ProductItem>
<name>…</name>
<type>…</type>
<make>…</make>
</ProductItem>
<ProductItem
name=“…”
type=“…”
make=“…”
/>
<ProductItem name=“…”
<type>…</type>
<make>…</make>
</ProductItem>
SOAP 1.2 no impone ninguna forma específica de codificar
Si da recomendaciones (que se pueden ignorar)
P.e. Codificaciones de arrays y estructuras que se pueden serializar en XML
Copyright Springer Verlag Berlin Heidelberg 2004
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
18
Ejemplo mensaje SOAP
<?xml version=‘1.0’ ?>
<SOAP:Envelope
xmlns:SOAP="http://www.w3c.org/2001/12/soap-envelop/"
xmlns:p =‘http://www.mafia.it/pizzas’>
<SOAP:Header>
<p:prioridad> urgente </p:prioridad>
<p:origen>cornelio@sicilia.it</p:origen>
</SOAP-ENV:Header>
<SOAP:Body>
<p:encargo>
<p:pizza nombre=‘Margarita’>
<p:tamaño> familiar </p: tamaño>
<p:comentario> con mucho queso </p: comentario >
</p:pizza>
</p:encargo>
</SOAP:Body>
</SOAP:Envelope>
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
19
Estructura y contenidos
de un mensaje SOAP: ejemplo
Ejemplo en estilo de interacción RPC
<?xml version='1.0' ?>
<env:Envelope xmlns:env="http://www.w3.org/2002/06/soap-envelope" >
<env:Header>
<t:transactionID
xmlns:t="http://intermediary.example.com/procurement"
env:role="http://www.w3.org/2002/06/soap-envelope/role/next"
env:mustUnderstand="true" >
57539
</t:transactionID>
</env:Header>
envelope
header
blocks
<env:Body>
<m:orderGoods
env:encodingStyle="http://www.w3.org/2002/06/soap-encoding"
xmlns:m="http://example.com/procurement">
<m:productItem>
<name>ACME Softener</name>
</m:productItem>
<m:quantity>
35
</m:quantity>
</m:orderGoods>
</env:Body>
body
</env:Envelope>
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
Copyright Springer Verlag Berlin Heidelberg 2004
20
Estructura y contenidos
de un mensaje SOAP: cabecera
o
SOAP permite especificar quien debería tratar la cabecera y que debería
hacer con esta. Con este propósito incluye:
Þ El atributo actor SOAP: quien debería procesar el header o bloque
particular. El nodo que procesa el mensaje puede jugar el papel:
none, next, ultimateReceiver.
• None es para propagar información que no debe ser procesada.
• Next indica que un nodo que reciba el mensaje puede procesar
este bloque.
• ultimateReceiver indica que la cabecera va dirigida al receptor
final del mensaje.
Þ El atributio mustUnderstand : con valores 1 o 0, para indicar si es
obligatorio procesar el header. Si un nodo puede procesar el mensaje
(como es indicado por el atributo actor), el atributo mustUnderstand
attribute determina si es obligatorio procesarlo. Si es obligatorio y
no puede se detiene cualquier procesado posterior y se genera un
fallo (fault).
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
21
<SOAP-ENV:Envelope
xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/"
SOAP-ENV:encodingStyle="http://schemas.xmlsoap.org/soap/encoding/"/>
<SOAP-ENV:Header>
<t:Transaction
xmlns:t="some-URI"
SOAP-ENV:mustUnderstand="1">
5
</t:Transaction>
</SOAP-ENV:Header>
<SOAP-ENV:Body>
<m:GetLastTradePrice xmlns:m="Some-URI">
<symbol>DEF</symbol>
</m:GetLastTradePrice>
</SOAP-ENV:Body>
</SOAP-ENV:Envelope>
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
22
Estructura y contenidos
de un mensaje SOAP: cuerpo (body)
o
o
o
o
El cuerpo es la información específica de la aplicación contenida en el mensaje
Una entrada de cuerpo ( o bloque) es sintácticamente equivalente a una entrada
de cabecera con atributos de actor= ultimateReceiver y mustUnderstand = 1
A diferencia de las cabeceras, SOAP no especifica nada sobre el contenido de los
bloques del cuerpo:
Þ Mapeo de RPC a una colección de bloques del cuerpo SOAP
Þ El bloque Fault (para representar errores en el procesamiento de un mensaje
SOAP)
El bloque fault tiene cuatro elementos (en v.1.1):
Þ fault code: indica la clase de error (version, mustUnderstand, cliente,
servidor)
Þ fault string: explicación legible del fallo
Þ fault actor: quien originó el fallo
Þ detail: información específica de la aplicación sobre la naturaleza del fallo
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
23
Estructura y contenidos
de un mensaje SOAP: cabecera
o
o
o
En la version 1.2, el bloque fault element se especifica en más detalle.
Debe contener dos sub-elementos obligatoriamente:
Þ Code: Contiene un valor (el código del fallo) y probablemente un
subcódigo (de información especifica de la aplicación)
Þ Reason: una cadena como en la v.1.1
Y puede contener algunos elementos adicionales:
Þ detail: como en la v.1.1
Þ node: la identificación del nodo que produjo el fallo (si no aparece,
por defecto es el receptor del mensaje)
Þ role: el role que juega el nodo que generó el fallo
Errores en la comprensión de una cabecera obligatoria a procesar se
responden con un bloque fault, pero también se incluye una cabecera
especial que indica cual de las cabeceras originales no se comprendió. .
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
24
SOAP: Fault (ejemplo)
<?xml version=‘1.0’ ?>
<SOAP:Envelope
xmlns:SOAP=‘http://www.w3c.org/2001/12/soap-envelop/’>
<SOAP:Body>
<SOAP:Fault>
<faultcode> soap: Receiver </faultcode>
<faultstring> Error al procesar el mensaje </faultstring>
<detail>
<p:detalles xmlns:p ‘http://www.mafia.it/pizzas’>
<mensaje>La pizza Barbacoa no puede llevar tanto queso </mensaje>
</p:detalles>
<detail>
</SOAP:Fault>
</SOAP:Body>
</SOAP:Envelope>
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
25
Ejemplo mensajes SOAP
Petición RPC
SOAP Envelope
SOAP header
Contexto
Transaccional
Respuesta RPC (una de las dos)
SOAP Envelope
SOAP header
SOAP Body
Nombre del
procedimiento
Input param 1
Input param 2
Contexto
Transaccional
SOAP Body
Return parameter
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
SOAP Envelope
SOAP header
Contexto
Transaccional
SOAP Body
Fault entry
26
Ejemplos de Codificación SOAP
Tipos Simples
<?xml version=‘1.0’ ?>
<SOAP:Envelope
xmlns:SOAP=‘http://www.w3.org/2001/12/soap-envelop/’
xmlns:xsi=“htpp://wwww.w3.org/2001/XMLSchema”
encodingStyle=‘http://www.w3.org/2001/12/soap-enconding’>
<SOAP:Body>
<p:pizza>
<p:código xsi:type:’soap:int’>234</p:codigo>
<p:tamaño xsi:type =‘soap:String’>familiar</p:tamaño>
</p:pizza>
</SOAP:Body>
</SOAP:Envelope>
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
27
Ejemplos de Codificación SOAP
Estructuras
Struct Pizza {
int codigo;
string nombre
};
<Pizza xmlns=‘cualquier_URI’>
<codigo>234</codigo>
<nombre>Barbacoa</nombre>
</Pizza>
Arrays
<pizzas xsi:type=‘soap:Array’ soap:arrayType=‘p:Pizzas[2]’>
<pizza> <codigo>234</codigo>
<nombre>Barbacoa</nombre>
</pizza>
<pizza><codigo>237</codigo>
<nombre>Barbacoa</nombre>
</pizza>
</pizzas>
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
28
Ejemplos de Codificación SOAP
Arrays parciales
<pizzas xsi:type=‘soap:Array’ soap:arrayType=‘p:Pizzas[10]’
soap:offser=‘[4]’>
<pizza> <codigo>234</codigo>
<nombre>Barbacoa</nombre>
</pizza>
<pizza><codigo>237</codigo>
<nombre>Barbacoa</nombre>
</pizza>
</pizzas>
<pizzas xsi:type=‘soap:Array’ soap:arrayType=‘p:Pizzas[10]’>
<pizza soap:position=‘2’> <codigo>234</codigo>
<nombre>Barbacoa</nombre>
</pizza>
< pizza soap:position=‘5’ ><codigo>237</codigo>
<nombre>Barbacoa</nombre>
</pizza>
</pizzas>
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
5º y 6º
elemento
2º y 5º
elemento
29
Mapeo de SOAP a un protocolo de
transporte
o
o
o
o
Un “binding” es una descripción de
como se envía un mensaje SOAP
utilizando un protocolo.
El binding típico de SOAP es HTTP
SOAP puede usar GET o POST.
Con GET, la petición no es un
mensaje SOAP pero la respuesta es
un mensaje SOAP, con POST la
petición y la respuesta son mensajes
SOAP (en la versión 1.2, la versión
1.1 considera sobre todo el uso de
POST).
La dirección del servidor: En el caso
de HTTP el URL, en el caso de
SMTP la dirección “to”. NO
FORMA parte del mensaje SOAP.
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
HTTP POST
SOAP
SOAP Envelope
Envelope
SOAP header
Transactional
context
SOAP Body
Name of Procedure
Input parameter 1
Input parameter 2
30
Una llamada RPC sobre SOAP
HTTP Post
SOAP envelope
SOAP header
transactional
context
SOAP body
cliente servicio
SOAP
engine
HTTP
engine
Implementación cliente
(otras capas)
name of the
procedure
input parameter 1
input parameter 2
HTTP Post
SOAP envelope
proveedor servicio
HTTP
engine
SOAP
engine
Implementación servicio
(otras capas)
SOAP header
transactional
context
SOAP body
return
parameter
Copyright Springer Verlag Berlin Heidelberg 2004
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
31
Una llamada RPC sobre SOAP
proveedor servicio
cliente servicio
implementación
cliente
invoca el servicio
como una llamada local
stub del cliente
invoca el SOAP engine para
construir el mensaje SOAP
SOAP engine
Mapea el mensaje SOAP en HTTP y lo
pasa a un cliente HTTP que lo envía al
proveedor
HTTP engine
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
implementación
del servicio
Invoca un procedimiento local que
Implementa el servicio
stub del servidor
El router parsea el mensaje,
identifica el stup apropiado, y envía
el mensaje parseado
SOAP router
pasa el contenido del mensaje HTTP
al router
HTTP server
Copyright Springer Verlag Berlin Heidelberg 2004
32
SOAP asíncrono
o
o
o
El Estilo RPC da lugar a sistemas muy acoplados
Þ Muchos sistemas B2B utilizan interacciones estilo documento
asíncronas.
Þ En lugar de interacciones directas, se usan colas.
Una forma de de lograr interacciones asíncronas SOAP es mediante el
protocolo STMP
Otra forma es utilizar procesos separados (idéntico a como ser haría con
sistemas basados en RPC para implementar RPC asíncronos)
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
33
SOAP como un protocolo sencillo
o
o
o
SOAP no incluye nada sobre
Þ fiabilidad
Þ intercambio de mensajes complejos
Þ transacciones
Þ seguridad
Þ…
Como tal, no es adecuado por si solo para implementar aplicaciones
industriales que incorporen características típicas de middlewares como
transacciones o envío fiable de mensajes
SOAP necesita que se estandaricen estas características:
Þ WS-security
Þ WS-Coordination
Þ WS-Transactions
Þ…
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
34
Ejemplo SOAP sencillo
1
2
3
4
5
6
7
8
9
10
11
12
13
// Fig. 29.1: SimpleService.java
// Implementation for the requested method on the server
public class SimpleService {
public String getWelcome( String message ) throws Exception
{
String text =
"Welcome to SOAP!\nHere is your message: " + message;
return text;
// response
La clase
SimpleService
reside en el servidor
El método devuelve un String
}
}
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
35
Apache SOAP
Disponible en:
xml.apache.org/soap
SOAP RPC requiere un servlet engine
como Tomcat
jakarta.apache.org
y
un parser como Xerces de Apache
Xml.apache.org/xerces-j/index.html
Axis (continuación)
http://ws.apache.org/
Herramienta de administración SOAP de Apache
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
36
Apache SOAP
Descripción del servicio servido
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
37
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
// Fig. 29.4 : GetMessage.java
// Program that makes a SOAP RPC
// import Java packages
import java.io.*;
import java.net.*;
import java.util.*;
// import third-party packages
import org.apache.soap.*;
import org.apache.soap.rpc.*;
APIs de la implementación
SOAP
public class GetMessage {
// main method
public static void main( String args[] ) {
String encodingStyleURI = Constants.NS_URI_SOAP_ENC;
String message;
if ( args.length != 0 )
message = args[ 0 ];
else
message = "Thanks!";
Cliente RPC
Especifica estilo
de codificación
de los mensajes
SOAP
Especifica URL del
servidor
// attempt SOAP remote procedure call
try {
URL url = new URL(
"http://localhost:8080/soap/servlet/rpcrouter" );
// build call
Call remoteMethod = new Call();
Postgrado Servicios
Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
remoteMethod.setTargetObjectURI(
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
"urn:xml-simple-message" );
Instancia objeto
Call y establece su
URI
38
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
// set name of remote method to be invoked
remoteMethod.setMethodName( "getWelcome" );
remoteMethod.setEncodingStyleURI( encodingStyleURI );
// set parameters for remote method
Vector parameters = new Vector();
parameters.addElement( new Parameter( "message",
String.class, message, null ) );
remoteMethod.setParams( parameters );
Response response;
// invoke remote method
response = remoteMethod.invoke( url, "" );
// get response
if ( response.generatedFault() ) {
Fault fault = response.getFault();
System.err.println( "CALL FAILED:\nFault Code = "
+ fault.getFaultCode()+ "\nFault String = "
+ fault.getFaultString() );
}
else {
Parameter result = response.getReturnValue();
// display result of call
System.out.println( result.getValue() );
}
Postgrado}Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
Construye parámetros
utilizados para invocar
método getWelcome
de SimpleService
Invoca método
getWelcome y
almacena el valor
devuelto en el objeto
Response
Muestra un
mensaje si ocurre
un error
Muestra el valor
devuelto por el método
si no hay error
39
67
68
69
70
71
72
73
74
75
76
77
78
79
80
// catch malformed URL exception
catch ( MalformedURLException malformedURLException ) {
malformedURLException.printStackTrace();
System.exit( 1 );
}
// catch SOAPException
catch ( SOAPException soapException ) {
System.err.println( "Error message: " +
soapException.getMessage() );
System.exit( 1 );
}
}
}
java GetMessage
Welcome to SOAP!
Here is your message: Thanks!
java GetMessage "my message”
Welcome to SOAP!
Here is your message: my message
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
40
Plataformas para servicios Web basados
en Java
o
Cada plataforma tiene diferentes formas de implementar los servicios
Web
Þ SUN: Java Web Services Developer Pack (JWSDP)
Þ CapeConnect (www.capeclear.com)
Þ Glue Standard (www-themindelectric.com)
Þ IONA Orbix E3A XMLBus (www.iona.com)
Þ WASP Server for Java (www.systinet.com)
Þ Axis (sucesor del Apache SOAP 2.2, xml.apache.org/axis)
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
41
WSDL:
Web Services Description Language
o
WSDL es equivalente a los IDLs, pero los Servicios Web son más
complejos de describir
Þ Además de definir las operaciones, hay que definir los mecanismos
de interacción (bindings).
• En middleware convencionales, siempre se usa el mismo middleware,
por lo que el mecanismo de acceso es implícito al middleware
u
Solo se aborda nombre de servicio y signatura
• En los servicios Web cada servicio se puede servir con distintos
protocolos
Þ Hay que indicar la localización del servicio
• En middleware convencionales la localización del objeto es transparente
(el middleware se encarga de localizar el objeto)
• La ausencia de una plataforma de servicios Web centralizada implica
conocer la localización donde enviar el mensaje SOAP
Þ Cabe la posibilidad del mismo servicio con distintos protocolos de
transporte y en diferentes localizaciones.
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
42
WDSL
o
Las interacciones son con frecuencia asíncronas en Servicios Web:
Þ Los IDLs convencionales describen un único punto de entrada al
servicio (una interacción RPC única)
Þ La invocación de un servicio Web suele conllevar el intercambio de
varios mensajes asíncronos. WSDL incluye una colección de
diferentes paradigmas de interacción, junto con la posibilidad de
combinar operaciones o grupos de operaciones en un interface.
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
43
Estructura de un Interface WSDL
o
Una especificación WSDL consta de:
Þ Una parte abstracta (analoga a un IDL)
• Se definen los tipos. Las estructuras de datos que se
intercambian.
u
Los esquemas XML tienen tipos de datos básicos, pero permiten
definir estructuras.
• Se definen los mensajes. Cada mensaje es un
documento tipado con partes. Cada parte se
caracteriza por un nombre y un tipo.
u
Por ejemplo, la invocación de un procedimiento con dos
parámetros, un entero y un real se puede definir como un mensaje
con dos partes
• Se definen las operaciones. Existen 4 tipos de
operación:
u
u
u
u
One-way: El cliente invoca un servicio enviando un único
mensaje. (1 mensaje, asíncrono)
Notificacions: El servidor envía un único mensaje (1 mensaje,
asíncrono)
Request-response: El servidor es invocado y responde (2
mensajes, síncrono)
Solicit-response: El servidor invoca y espera respuesta (2
mensajes, síncrono)
especificación WSDL
parte abstracta
tipos
mensajes
operaciones
tipos de puertos
parte concreta
bindings
servicios y
puertos
• Se definen tipos de puerto, que agrupan operaciones.
Þ Una parte concreta:define el protocolo de transporte
(binding) y otras informaciones
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
Copyright Springer Verlag Berlin Heidelberg 2004
44
Estructura de un Interface WSDL
Þ Para definir (concretar) una instancia de servicio real, se
tiene que definir :
• El conjunto exacto de puertos que implementa
• Los protocolos de transporte usados en la
implementación de los tipos de puertos
• Las direcciones en los que estas accesibles
• El mismo tipo de mensaje, puede ser codificado de
distintas maneras.
Þ Una parte concreta consta de:
1. InterfaceBindings:
u
Especifica la codificación del mensaje y el
protocolo de transporte (protocol bindings) para
todas las operaciones y mensajes definidos en un
tipo de puerto. Por ejemplo:
–
–
–
Una operación en estilo RPC o documento
El mensaje de una operación tiene que utilizar SOAP como
protocolo de aplicación, y HTTP como protocolo de
transporte.
Reglas de codificación utilizadas para serializar partes de
un mensaje en XML. Dos opciones: literal (utilizado
normalmente en document style, toma las definiciones de
esquema XML) y encoding (utilizado normalmente en
estilo RPC, utiliza reglas de codificación SOAP).
especificación WSDL
parte abstracta
tipos
mensajes
operaciones
tipos de puertos
parte concreta
bindings
servicios y
puertos
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
Copyright Springer Verlag Berlin Heidelberg 2004
45
Estructura de un Interface WSDL
Þ Una parte concreta consta de (cont.):
2. Ports (EndPoints):
u Combinan la información de los
InterfaceBindings con direcciones de red
(especificados por URI) en la que se puede
acceder a la implementación del tipo de puerto.
3. Servicios:
u Agrupaciones lógicas de puertos. Un servicio
específico WSDL podría estar accesible en
diferentes direcciones (p.e. URIs de diferentes
máquinas, una em Europa y otra en América)
u Normalmente un servicio WSDL agrupa puertos
relacionados, disponibles con frecuencia en una
misma dirección.
u Otra agrupación posible es utilizar diferentes
ports que representan diferentes bindings del
mismo tipo de puerto.
u Permiten, en definitiva, que la misma
funcionalidad sea accesible en diferentes estilos
de interacción y con diferentes protocolos de
transporte.
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
especificación WSDL
parte abstracta
tipos
mensajes
operaciones
tipos de puertos
parte concreta
bindings
servicios y
puertos
Copyright Springer Verlag Berlin Heidelberg 2004
46
Estructura de un Interface WSDL
o
o
o
o
Añadiendo InterfaceBindings, Ports y Services, la definición del
interface se va “concretando”.
Con la información de binding, los usuarios conocen que protocolos
usar, como estructurar los mensajes XML, y que se espera al enviar el
mensaje.
Þ WSDL 1.1 define en la actualidad extensiones binding para SOAP,
HTTP GET y POST, y MIME.
Con la información de port, el usuario conoce la dirección en la que se
implementa un tipo de puerto.
Con el service el usuario conoce todos los puertos que están
implementados como un grupo.
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
47
<?xml version="1.0"?>
<definitions name="Procurement"
targetNamespace="http://example.com/procurement/definitions"
xmlns:tns="http://example.com/procurement/definitions"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
xmlns:soap="http://schemas.xmlsoap.org/wsdl/soap/"
xmlns="http://schemas.xmlsoap.org/wsdl/" >
Ejemplo
WSDL
<message name="OrderMsg">
<part name="productName" type="xs:string"/>
<part name="quantity" type="xs:integer"/>
</message>
<portType name="procurementPortType">
<operation name="orderGoods">
<input message = "OrderMsg"/>
</operation>
</portType>
abstract
part
messages
operation and
port type
<binding name="ProcurementSoapBinding" type="tns:procurementPortType">
<soap:binding style="document"
transport="http://schemas.xmlsoap.org/soap/http"/>
<operation name="orderGoods">
<soap:operation soapAction="http://example.com/orderGoods"/>
<input>
<soap:body use="literal"/>
</input>
<output>
<soap:body use="literal"/>
</output>
</operation>
</binding>
concrete
part
<service name="ProcurementService">
<port name="ProcurementPort" binding="tns:ProcurementSoapBinding">
<soap:address location="http://example.com/procurement"/>
</port>
</service>
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
</definitions>
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
port and
service
binding
Copyright Springer Verlag Berlin Heidelberg 2004
48
Ejemplo WSDL
<?xml version=“1.0” encoding=“utf-8”?>
<definitions xmlns:s=…
<types>
<s:schema
<s:element name=“suma”>
<s:complex Type>
<s:sequence>
<s:element minOccurs=“1” maxOccus=“1” name=“a” type=“s:int”/>
<s:element minOccurs=“1” maxOccus=“1” name=“b” type=“s:int”/>
</s:sequence>
</s:complex Type>
</s:element>
….
abstracta
<message name=“sumaSoapIn”>
<part name=“parameters” element=“s0:suma”/>
</message>
…
+
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
49
Ejemplo WSDL
…
<portType name=“ServicioSumaSoap”>
<operation name=“suma”>
<input message=“sO:sumaSoapIn/>
<output message=“sO:sumaSoapOut”/>
</operation>
</portType>
…
<binding name =“ServicioSumaSoap” type=“sO:ServicioSumaSoap”>
<soap:binding transport=“http://schemas.xmlsoap.org/soap/http” style=“document” />
<operation name=“suma”>
<soap:operationsoapAction=“http://tempuri.org/suma” style=“document” />
<input> <soap:body use=“literal” /> </input>
<output> <soap:body use=“literal”/> </output>
</operation>
</binding>
<service name=“ServicioSuma”>
<port name=“ServicioSumaSoap” binding=“s0:ServicioSumaSoap”>
<soap:address location=http://localhost/Suma/Service1.asmx“ />
<port>
</service>
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
</definitions>
Departamento
de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
abstracta
concreta
50
Implicaciones del Modelo WSDL
o
o
o
Los diferentes tipos de interacción:
Þ Suponen que un servidor puede invocar servicios (se comporta como
un cliente). Típico en middlewares orientados a mensajes.
La ventaja de la separación de la parte abstracta y concreta es que la
primera puede reutilizarse
Þ Un WDSL puede importar otro WDSL. Por ejemplo, un WDSL
puede importar la parte abstracta y concretar los “bindings” y las
“direcciones”.
Si los mensajes definido en WSDL se intercambian en SOAP, entonces
el InterfaceBinding contiene toda la información necesaria para construir
automáticamente los mensajes SOAP.
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
51
Utilización de WSDL
o
El W3C ha identificado tres usos potenciales de WSDL:
1. Lenguaje de descripción de servicio tradicional (contrato que implementa
un Servicio Web).
Þ
El contrato indica como interactuar con el servicio, datos a enviar y devolver,
operaciones involucradas y el formato y protocolo.
2. Entrada para compiladores de stub y otras herramientas:
Þ
Þ
Las bases de datos comerciales han comenzado a ofrecer funcionalidad para generar
automáticamente las descripciones WSDL de procedimientos almacenados
Los servidores de aplicaciones dan facilidades para generar stubs de documento WSDL y
para generar WSDL de clases (p.e. Clases java).
3. Uso no definido claramente por el W3C en referencia a la semántica.
Þ
WSDL para capturar la información que permitirá a los diseñadores razonar sobre la
semántica de los servicios.
¡Pero la semántica está fuera en estos momentos de la especificación WSDL!
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
52
Utilización de WSDL
WSDL del
proveedor del
servicio
1
2
compilador WSDL
(lado del cliente)
generador
WSDL
compilador WSDL
(lado del servidor)
cliente servicio
service provider
objeto de aplicación
proveedor servicio)
objeto de aplicación
(cliente)
stub
skeleton
middleware
basado en SOAP
middleware
basado en SOAP
Mensajes SOAP
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
Copyright Springer Verlag Berlin Heidelberg 2004
53
UDDI: Universal Description Discovey
and Integration
o
o
Primera propuesta en Septiembre de 2000 (IBM, Ariba y Microsoft), desde la
versión 3 (julio 2002) bajo el paraguas OASIS
Objetivos UDDI:
Þ Especificar un framework para describir y descubrir servicios Web
Þ Todo gira alrededor de la noción de bussines registry (un servicio de
nombres y directorio)
• La idea era registrar cada servicio desarrollado en el mundo
Þ UDDI define estructuras de datos y APIs para publicar descripciones de
servicios y buscar servicios.
Þ Al ser a su vez un servicio Web, las APIs de UDDI están también
especificadas en WSDL con SOAP.
Þ Permite dos cosas_
• A los desarrolladores encontrar información para escribir los clientes de
los servicios
• Permite “dynamic binding”, permitiendo a los clientes preguntar al
registro y obtener las referencias a los servicios de interés.
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
54
UDDI
o
Se clasifica en función de para que se usa la información (similar a
directorio telefónico)
Þ Páginas blancas: Información de contacto.listados
de organizaciones
contacto
y servicios. Los cliente UDDI pueden encontrar servicios Web
dados por una empresa.
Þ Páginas amarillas: Información de industria.
industria clasificación de
compañías y servicios Web de acuerdo a una taxonomía.
Þ Páginas Verdes: Información técnica y especificaciones. Describe
como puede ser invocado un servicio Web. Punteros a descripciones
de servicios (descripciones externas al registro UDDI).
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
55
Estructuras de datos UDDI
o
Un registro UDDI contiene cuatro tipos de información:
Þ BusinessEntity:Describe la organización que ofrece el servicio.
• Nombre, dirección y otra información de contacto.
Þ BusinessService:Grupo de servicios Web relacionados ofrecido por una
BusinessEntity (empresa), pero ofrecida en diferentes direcciones,
versiones, y tecnologías. Al igual que las BusinessEntity, pueden incluir
información de clasificación.
• Corresponde con una clase de servicio (p.e. Reserva de viaje)
Þ BusinessTemplate:Información técnica para utilizar el servicio.
• Dirección del servicio
• Referencias documentos (tModels) describiendo el interface u otras
propiedades.
• Como dar valor a los parámetros y valores por defecto
Þ tModels (Technical model): Contenedor genérico para cualquier
especificación. P.e. Puede representar un interface de servicio en WSDL,
una clasificación, un protocolo de interacción, o la semántica de una
operación.
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
56
businessEntity
nombre
contactos
descripción
indentificadores
categorías
businessService
clave de servicio
nombre
descripción
categorías
bindingTemplate
clave de binding
descripción
dirección
información detallada
referencia a tModels
tModel
tModel
tModel
key
key
clave
name
name
nombre
description
description
descripción
overviewDoc
overviewDoc
Documento (overviewDoc)
identifiers
identifiers
indentificadores
categories
categories
categorías
tModel
tModel
key
clave
name
nombre
description
descripción
overviewDoc
documento(overviewDoc)
identifiers
indentificadores
categories
categorías
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
Especificaciones
almacenadas en
el sitio del
proveedor
Almacenado en el registro UDDI Copyright Springer Verlag Berlin Heidelberg 2004
57
modelo de datos UDDI
io
vic
r
e
s
un del
e
r
o
sob tM
e
v
la
un
n c a en
ó
i
c
c
ma pecifi
r
o
inf se es
La
Proveedor: Información sobre la entidad que
ofrece el servicio
tModel: Descripciones de especificaciones
de servicios
0..n
Servicio: Información sobre una familia
particular de ofertas
0..n
Binding: Información técnica sobre un punto
De entrada a un servicio
0..n
Bindings contienen referencias
a tModels. Estas referencias
declaran las especificaciones
del interface.
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
58
Ejemplo de un tModel UDDI
Descripción del API UDDI
Especificación en WSDL
overviewDoc
(especificaciones
en WSDL y del
API)
<tModel tModelKey=”uddi:uddi.org:v3_publication”>
<name>uddi-org:publication_v3</name>
<description>UDDI Publication API V3.0</description>
<overviewDoc>
<overviewURL useType=”wsdlInterface”>
http://uddi.org/wsdl/uddi_api_v3_binding.wsdl#UDDI_Publication_SoapBinding
</overviewURL>
</overviewDoc>
<overviewDoc>
Especificación en lenguaje natural
<overviewURL useType=”text”>
http://uddi.org/pubs/uddi_v3.htm#PubV3
</overviewURL>
</overviewDoc>
información de
clasificación
(especifica que
este tModel trata
de especificaciones
XML, WSDL, y
SOAP)
<categoryBag>
Un tModel puede
<keyedReference keyName=”uddi-org:types:wsdl”
a otros tModels
keyValue="wsdlSpec"
tModelKey="uddi:uddi.org:categorization:types”/>
<keyedReference keyName=”uddi-org:types:soap”
keyValue="soapSpec"
tModelKey="uddi:uddi.org:categorization:types”/>
<keyedReference keyName=”uddi-org:types:xml”
keyValue="xmlSpec"
tModelKey="uddi:uddi.org:categorization:types”/>
<keyedReference keyName=”uddi-org:types:specification”
keyValue="specification"
tModelKey="uddi:uddi.org:categorization:types”/>
</categoryBag>
hacer referencia
</tModel>
Copyright Springer Verlag Berlin Heidelberg 2004
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
59
API del registro UDDI
o
o
Tres tipos de clientes
Þ Los proveedores de servicio que publican
Þ Los clientes que buscan
Þ Otros registros que intercambian información
Seis conjuntos de APIs
1.
Pregunta/Búsqueda de servicio (UDDI Inquiry API):
§ Para obtener información que satisfaga ciertos criterios
•
§
Para obtener detalles de una entidad específica
•
§
2.
find_business, find-services, find_binding, find_tModel
get_bussinesDetail, getServiceDetail, get_bindingDetail,
get_tModelDetail
Este API es para browsers utilizados por desarrolladores, o por clientes que
realizan dynamic binding
Publicación de servicio (UDDI Publishers API):
§ Para proveedores de servicio. Permite añadir, modificar y eliminar entradas.
Ejemplo operaciones:
•
Save_business, save_service, save_binding,save_tModel,
delete_service, delete_binding, delete_tModel
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
60
API del registro UDDI
3.
Seguridad (UDDI Security API):
§ Permite a los usuarios UDDI obtener y deshacerse de tokens para ser utilizados
en posteriores comunicaciones con el registro:
•
4.
Custodia y transferencia de pertenencia (UDDI Custody and Ownership Transfer
API):
§ Permite a los registros transferir la custodia de la información entre ellos, y
transferir la posesión de estas estructuras de unos a otros:
•
5.
get_transferToken, transfer_entities, transfer_custody
Suscripción (UDDI Suspscription API):
§ Permite monitorizar los cambios en el registro suscribiéndose al seguimiento de
nuevas entradas, modificaciones o eliminaciones de entradas
•
6.
get_authToken, discard_authToken
delete__subscription, get_subscriptionResults,
get_subscription, save_subscription
Replica (UDDI Replication API):
§ Soporta la replicación de información en distintos registros, de forma que se
pueda sincronizar su información.
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
61
API del registro UDDI
cliente servicio
SOAP/HTTP
API Búsqueda
proveedor servicio
Se mantiene diferentes puntos de acceso
(URIs) para clientes, proveedores y
Otros registros
•Los clientes no precisan autentificación
•Los proveedores y los otros registros si
SOAP/HTTPS
API Publicación
API Publicación
interface Servicio Web
interface Servicio Web
descripciones de servicios
API Búsqueda
APIs de
Suscripción,
replicación, y
transferencia de
custodia
(SOAP/HTTPS)
Registro UDDI A
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
descripciones de servicios
Registro UDDI B
Copyright Springer Verlag Berlin Heidelberg 2004
62
Ejemplo de trabajo
o
Un usuario puede encontrar una descripción WSDL de la siguiente
manera
1. Utiliza find_tModel para recuperar una lista de claves tModels
(tModel keys) corrrespondientes a entradas wsdlSpec. En el
ejemplo se pregunta por todos los servicios de precios de libros que
estén en wsdl.
<?xml version="1.0"?>
<find_tModel generic="1.0" xmlns="urn:uddi-org:api">
<categoryBag>
<keyedReference tModelKey="UUID:C25893AF-1977-3528-36B5-4192C2AB9E2C"
keyName="uddi-org:types" keyValue="wsdlSpec"/>
<keyedReference tModelKey="UUID:A15019C5-AE14-236C-331C-650857AE0221"
keyName="book pricing"
keyValue="36611349"/>
</categoryBag>
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
63
Ejemplo de trabajo
2. Utiliza get_tModelDetail para recuperar los tModels especificados
por las descripciones específicas de servicios .
3. Examina el campo overviewDoc para recuperar el contenido del
documento WSDL que describe el interface.
Proveedor servicio
cliente servicio
Descripciones
WSDL del
servicio
SOAP/HTTP
SOAP/HTTPS
API Búsqueda
API publicación
tModel
interface servicio Web
businessEntity
Copyright Springer Verlag Berlin Heidelberg 2004
Descripciones servicio
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
Registro UDDI
businessService
bindingTemplate
64
proveedor de servicio
Implementación
servicio
Pasos para
publicar un
servicio
Web
server stub
1
Generador
WSDL
descripción del
servicio en WSDL
SOAP router
compilador
WSDL
HTTP engine
Publicación en
UDDI
2
3
businessEntity
businessService
bindingTemplate
API de búsqueda
tModel
API publicación
registro UDDI
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
Copyright Springer Verlag Berlin Heidelberg 2004
65
Bibliografía
o
Material elaborado a partir del libro y del material que acompaña al libro
en http://www2.inf.ethz.ch/~alonso/WebServicesBook.html
Web Services
Concepts, Architectures
and Applications
Springer Verlag 2004
ISBN 3-540-44008-9
By Gustavo Alonso, Fabio Casati, Harumi Kuno, Vijay Machiraju
o
y del libro: Advanced Java 2 Platform - How to program- y del material
que lo acompaña en http://www.deitel.com/books/downloads.html
by Deitel, Deitel, Satry ISBN: 0130895601
Postgrado Servicios Web, Seguridad Informática y Aplicaciones de Comercio Electrónico
Departamento de Informática e Ingeniería de Sistemas (Univ. Zaragoza)
66
Descargar