Speaker : David Delabassee, Software Evangelist working in the GlassFish and Java EE Team at Oracle
Abstract :
Java EE 8 vient juste d’être finalisé! Cette session se propose de faire le point sur cette mise à niveau de la plateforme.
Durant cette soirée, nous allons aborder les principales nouvelles fonctionnalités de Java EE 8 tels que JAX-RS et sa nouvelle API client ‘Reactive’, l’API Servlet 4 et son support http/2, la nouvelle API JSON-B, les différentes améliorations liées à la sécurité. Nous allons aussi voir ce qu’apporte Bean Validation 2.0, CDI 2.0, JSON-P 1.1, etc.En conclusion, nous allons faire le point sur les annonces faites à JavaOne comme par exemple EE4J, le projet au sein de la Fondation Eclipse qui va accueillir le développement de la plateforme Java EE.
Répondre à des questions telles que la convergence (ou pas) de MicroProfile.IO et de Java EE, etc…
Etaient présents pour Softeam :
-
Guillaume LEMONT
-
Thomas SCHWENDER
-
Sortie officielle de JEE 8 le 21 septembre 2017
-
confirmation que JEE 8 tourne avec Java 8 (et ce sera également valable pour Java 9)
-
-
Glassfish 5 implémentation de référence
-
Jersey est l’implémentation de référence
-
Possibilité de composer / combiner des appels de services via la Reactive Client API et la l’interface
CompletionStage
(voir thenCompose et thenCombine).
Ce RX Invoker est l’un des principaux ajouts de JAX-RS 2.1 -
Server-Sent Events (qui sont maintenant supportés par la plupart des navigateurs)
L’actuelle JSON Parser. Pour de spec pour cette version (idem pour la version 1.0), tout est déjà contenu dans la Javadoc
-
Nouvelle API pour le binding de formats JSON en objets Java.
-
Est à JSON ce que JAX-B est pour XML
-
"convention over configuration"
-
n’est pas là pour réinventer la roue, car de nombreuses API similaires existent sur le marché.
-
l’objet
Jsonb jsonb = JsonbBuilder.create()
permet de tout gérer.
-
Principal fact : apporte HTTP/2
-
conserve la sémantique HTTP/1 (on récupére la même chose)
-
le principal intérêt de HTTP/2 est d'améliorer les perf côté réseau (single TCP connection, 1 seul socket ouvert).
-
-
Define behavior of CDI outside of a Java EE container
-
spec split into 3 parts :
-
CDI core
-
CDI for Java SE
-
CDI for Java EE
-
-
Nouvelle API pour JEE 8
-
introduit la notion d'Identity Store
-
et la notion d'Authentication Mechanism
-
et finalement celle de Security Context
Le nouveau nom du projet au sein de la fondation Eclipse (principalement pour des raisons légales) : EE4J (Eclipse Enterprise for Java)
A partir de là, tout le monde coupe portable et PC, afin de pouvoir discuter tranquillement de ce "sujet sensible".
Les questions du public ont tourné autour des raisons d’Oracle de donner JEE à la fondation Eclipse.
Le contenu de JEE 8 était bien moins fourni que pour les précédentes versions, et nombreux étaient ceux qui pensaient qu’Oracle faisait cela pour se "débarasser" du produit qui ne leur rapportait pas assez par rapport aux ressources consommées.
David a répondu avec sa vision, qui devrait être celle d’Oracle, à savoir ne plus être seuls à maintenir le projet, et a confirmé une réduction du nombre de ressources affectées au projet.
Oracle continuera à participer au développement, mais dans une moindre mesure par rapport aux années passées (ce qui personnellement ne me rassure pas vu le peu d’activité constatée durant les derniers mois…)
Par contre, il a confirmé que plusieurs autres acteurs de la spécification avait accepté de participer davantage : IBM et RedHat pour les principaux.
Une fois de plus nous pouvons nous demander si cela va relancer la spécification, ou sceller son sort.
Note
|
Actuellement, 3 briques de JEE ne sont pas la propriété d’Oracle (et ne pourrons donc pas être données à la fondation Eclipse) :
|
Parmi les composants de JEE donnés à la fondation Eclipse, on aurait :
-
le TCK
-
l’implémentation de référence de la JSR
La spécification JSR ne sera PAS donnée.
Le JCP serait remplacé par une autre structure (et donc ne serait pas donné). David a parlé de "construction intellectuelle", et de nouvelles spécifications basées sur celles du JCP (ce qui semble… compliqué)
Note
|
Autre info en passant, David espère voir un rapprochement de EE4J avec Eclipse MicroProfile |