jax-ws e jax-rs

17
JAX-WS e JAX-RS Come sviluppare servizi SOAP e REST in standard JAX-WS e JAX-RS su Liferay Antonio Musarra, Software e Architectural Consultant, Key-Biz Srl

Upload: antonio-musarra

Post on 06-Jan-2017

372 views

Category:

Technology


1 download

TRANSCRIPT

Page 1: JAX-WS e JAX-RS

JAX-WS e JAX-RS Come sviluppare servizi SOAP e REST in standard JAX-WS e

JAX-RS su Liferay

Antonio Musarra, Software e Architectural Consultant, Key-Biz Srl

Page 2: JAX-WS e JAX-RS

@antonio_musarra

Antonio Musarra (@antonio_musarra)Software e Architectural Consultant, Key-Biz Srl

Web: http://www.key-biz.itBlog: http://www.dontesta.it/blogGitHub: https://github.com/amusarraSlideShare: http://www.slideshare.net/amusarra

Ho iniziato il mio viaggio nel mondo dell'informatica da un Olivetti M24 dotato di un processore Intel 8086 acquistato da mio padre esclusivamente per il suo lavoro. Non ho mai

posseduto console di nessun genere (Commodore, Amiga, etc…) e inizialmente quell'enorme scatola mi terrorizzava, terrore durato poco; giorno dopo giorno prendevo

rapidamente il controllo fino a quando….Ho sempre creduto che la condivisione della conoscenza sia un ottimo mezzo per la crescita

personale e questo è stato uno dei principali motivi che mi ha spinto sei anni fa a creare il mio blog personale www.dontesta.it

Dicono di me che sono bravo nell'analizzare e risolvere rapidamente i problemi complessi. La mia attività odierna è quella di consulente in progetti enterprise che utilizzano tecnologie

Web Oriented come J2EE, Web Services, ESB, TIBCO.

Page 3: JAX-WS e JAX-RS

Java standard per Web ServiceJAX-WS (Java API for XML Web Services): è un insieme di API Java dedicate allosviluppo di servizi web. L'insieme fa parte della piattaforma Java EE. JAX-WS usaannotazioni per semplificare lo sviluppo e le implementazioni di client. JAX-WS include Java Architecture for XML Binding (JAXB) e SOAP.

@antonio_musarra

JAX-RS (Java API for RESTful): è un insieme di API Java dedicate allo sviluppo di servizi web in base al pattern architetturale Representational State Transfer (REST). L'insieme fa parte della piattaforma Java EE. JAX-RS usa annotazioni per semplificare lo sviluppo e le implementazioni di client.

Page 4: JAX-WS e JAX-RS

Liferay Web Service• La generazione e l’invocazione dei servizi web è una parte centrale della esperienza di

sviluppo Liferay• Liferay senza servizi web sarebbe come una macchina di lusso senza ruote.• Fortunatamente, Liferay è dotato di una serie completa di servizi JSON e SOAP che

espongo tutte le funzionalità core. • Liferay offre anche il framework (Service Builder) per generare servizi locali e remoti

per le tue applicazioni.

@antonio_musarra

Page 5: JAX-WS e JAX-RS

Standard JAX-WS e JAX-RS

@antonio_musarra

• Dalla versione 7 Liferay supporta i due standard java per i servizi web JAX-WS e JAX-RS

• L’implementazione dei due standard JAX-WS e JAX-RS che Liferay ha deciso di adottare è Apache CXF

• Ogni Apps può pubblicare i servizi web su endpoint Apache CXF definiti sulla propria istanza Liferay

• Gli endpoint Apache CXF sono effettivamente percorsi di contesto (o context path) dei servizi web dove vengono distribuiti e resi accessibili

• E’ possibile definire sulla propria istanza Liferay uno o più endpoint Apache CXF • Per accedere ai servizi web, un extender deve essere configurato nell'istanza Liferay

Page 6: JAX-WS e JAX-RS

Liferay SOAP e REST Extender

@antonio_musarra

Gli Extenders specificano dove i servizi vengono distribuiti e se hanno handler, filter, provider, etc. Ci sono due tipi di extender:

• SOAP Extenders: Richiesto per la pubblicazione di servizi web JAX-WS in grado di distribuire su uno o più endpoint CXF con la possibilità di configurare handler, filter, provider, etc.

• REST Extenders: Richiesto per la pubblicazione di servizi web JAX-RS e offre servizi analoghi all’extender SOAP.

JAX WS APIJSR-224

JAX RS APIJSR-370

Apache CXF(v. 3.0.3)

Liferay SOAP Extender

Liferay REST Extender

My Liferay 7 App

Rest Service SOAP Service

Page 7: JAX-WS e JAX-RS

Liferay SOAP e REST Extender

@antonio_musarra

• I SOAP e REST Extender sono dei sottosistemi che tracciano i servizi corrispondenti ai filtri OSGi specificati in configurazione e li distribuiscono sotto a specifici endpointCXF

• Tramite i filtri OSGi posso istruire gli extender per registrare non solo i servizi web REST e SOAP ma anche per indicare quali sono i componenti che implementano gli eventuali handler, filter e provider

• Gli endpoint CXF per entrambi i tipi di extender possono essere creati a livello di codice o tramite il Pannello di controllo di Liferay

Page 8: JAX-WS e JAX-RS

Liferay SOAP e REST Extender

@antonio_musarra

Per ogni extenders abbiamo la possibilità di configurare ogni elemento tramite Pannello di controllo Liferay o per via programmatica attraverso l’indicazione sul file bnd di quale sia il file di configurazione da adottare per il bundle che contiene i servizi web.

Page 9: JAX-WS e JAX-RS

Pubblicazione dei servizi JAX-RS

@antonio_musarra

È possibile pubblicare un servizio web JAX-RS che risiede all’interno di un modulo Liferay così come si farebbe al di fuori di Liferay. A seguire l’esempio di un servizio.

Page 10: JAX-WS e JAX-RS

Pubblicazione dei servizi JAX-WS

@antonio_musarra

È possibile pubblicare un servizio web JAX-WS che risiede all’interno di un modulo Liferay così come si farebbe al di fuori di Liferay. A seguire l’esempio di un servizio

Page 11: JAX-WS e JAX-RS

Costruiamo un progetto d’esempio

@antonio_musarra

Supponiamo che un sistema esterno abbia bisogno di accedere ad un set di dati che risiedono su Liferay attraverso un set di API semplici esposte via JAX-RS e JAX-WS. Come procedere?

• Definire l’insieme d’interfacce, quindi il set di API• Implementare l’insieme d’interfacce come servizi locali• Implementare l’endpoint JAX-RS per i servizi web REST• Implementare l’endpoint JAX-WS per i servizi web SOAP• Configurare gli Extender SOAP e REST sull’instanza di Liferay

Page 12: JAX-WS e JAX-RS

Costruiamo un progetto d’esempio

@antonio_musarra

Il progetto Liferay è organizzato in moduli distribuiti così come indicato nella mappa e ogni modulo è poi i realtà un bundle OSGi che andrà installato sull’istanza Liferay. La nostra istanza Liferay conterrà quindi quattro bundle OSGi.

Page 13: JAX-WS e JAX-RS

Costruiamo un progetto d’esempio

@antonio_musarra

I due bundle rappresentano i due endpoint JAX-RS e JAX-WS che implementano le API definite dal modulo Custom User Service API. In figura sono evidenti gli endpoint CXF e i filtri OSGi che consento agli extender la registrazione come servizi.

Page 14: JAX-WS e JAX-RS

Costruiamo un progetto d’esempio

@antonio_musarra

Nel class diagram sono indicate le interfacce e le implementazioni dei servizi locali e remoti esposti come endpoint JAX-WS e JAX-RS

Page 15: JAX-WS e JAX-RS

Deploy e test dei servizi

@antonio_musarra

Dopo il deploy del progetto abbiamo attivi i quattro bundle OSGi, così come visibile nella figura a seguire (esecuzione del comando lb | grep Custom). Da questo momento i servizi web sono disponibili.

Gli endpoint dei servizi web (sulla propria istanza Liferay) sono:

• http://localhost:8080/o/rest/ext.persons• http://localhost:8080/o/web-services/CustomUserServiceWSEndPoint

Page 16: JAX-WS e JAX-RS

Deploy e test dei servizi

@antonio_musarra

In figura l’esempio un esempio di chiamata al servizio web JAX-RS appena installato. La chiamata è stata eseguita tramite il comando curl.

curl -v http://localhost:8080/o/rest/ext.persons/list/tag/it-architect | prettyjson

In questo caso il servizio restituisce i contatti Liferay che sono taggati con il valore it-architect.

Page 17: JAX-WS e JAX-RS

Ci vediamo al prossimo Symposium

@antonio_musarra

…Però, se siete curiosi di scoprire di più su Liferay 7:

• http://www.dontesta.it/blog• http://www.slideshare.net/amusarra• https://github.com/amusarra• https://dev.liferay.com

…e nel frattempo scaricate l’intero progetto da https://github.com/amusarra/liferay-web-services-jaxwsrs

Antonio Musarra@antonio_musarra

Grazie!