Configurez un projet Maven / Gradle avec des dépendances JAX-RS comme Jersey; 2. Créez une ressource REST en utilisant des annotations telles que @Path et @get; 3. Configurez l'application via une sous-classe d'application ou web.xml; 4. Ajouter Jackson pour la liaison de JSON en incluant Jersey-Media-Json-Jackson; 5. Déployer sur un serveur Jakarta EE ou un conteneur servlet et tester avec des outils comme Curl; Jakarta EE fournit une plate-forme standardisée de qualité d'entreprise pour créer des API reposantes fiables et portables en utilisant les spécifications officielles de Java, ce qui le rend idéal pour les environnements hiérarchisés par la stabilité et le support à long terme.
La construction d'API RESTful en Java avec Jakarta EE est un choix solide pour les applications de qualité d'entreprise qui apprécient la stabilité, la conformité des normes et l'intégration avec l'écosystème Java plus large. Jakarta EE (anciennement Java EE) fournit une plate-forme robuste et axée sur les spécifications pour développer des services de repos évolutifs et maintenables à l'aide de Jax-RS (Jakarta Restful Web Services).

Voici comment construire une API RESTful en Java en utilisant Jakarta EE:
1. Configurez votre projet Jakarta EE
Commencez par configurer un projet Maven ou Gradle avec les dépendances nécessaires. Si vous utilisez Maven , incluez l'API JAX-RS et un runtime compatible comme Eclipse Jersey (implémentation de référence) ou Apache CXF , ou déploie sur un serveur Jakarta EE complet comme Payara , Wildfly ou Open Liberty .

Exemple d'extrait pom.xml
à l'aide de Jersey:
<dépendances> <dépendance> <GroupId> org.glassfish.jersey.core </romproudID> <ArtefactId> Jersey-Server </Retifactid> <version> 3.1.3 </ version> </Dependance> <dépendance> <GroupId> org.glassfish.jersey.Containers </rombandid> <ArtefactId> Jersey-Container-Service </ ArfactId> <version> 3.1.3 </ version> </Dependance> <dépendance> <GroupId> org.glassfish.jersey.inject </rom grouped> <ArtefactId> Jersey-Hk2 </letefactive> <version> 3.1.3 </ version> </Dependance> </DENDENDENCES>
Ou, si vous utilisez un serveur d'applications Jakarta EE complet (comme Payara), la plupart des API sont déjà incluses.

2. Créez une classe de ressources de repos
Utilisez des annotations JAX-RS pour définir les points d'extrémité. Le @Path
, @GET
, @Produces
, etc., facilite la cartographie des méthodes HTTP sur les méthodes Java.
import jakarta.ws.rs. *; import jakarta.ws.rs.core.mediaType; import jakarta.ws.rs.core.Response; @Path ("/ utilisateurs") @Produces (mediatype.application_json) classe publique userresource { @OBTENIR Réponse publique getAlLUSERS () { // en pratique, récupérer à partir d'un service ou d'une base de données var utilisateurs = java.util.list.of ( nouvel utilisateur (1L, "Alice"), nouvel utilisateur (2L, "Bob") )); return réponse.ok (utilisateurs) .build (); } @OBTENIR @Path ("/ {id}") Réponse publique GetUserById (@PathParam ("id") Long ID) { if (id == 1) { return réponse.ok (nouvel utilisateur (1L, "Alice")). build (); } autre { return réponse.status (réponse.status.not_found) .build (); } } @POSTE @Consumes (mediatype.application_json) Réponse publique CreateUser (utilisateur utilisateur) { // Simuler la création user.setid (3l); // Attribuez l'ID return réponse.status (réponse.status.Created) .entity (utilisateur) .build (); } }
Et un enregistrement ou une classe User
simple:
Utilisateur d'enregistrement public (ID long, nom de cha?ne) { public void setid (long id) { // nécessaire pour certains mappeurs JSON si vous utilisez un comportement mutable } }
3. Configurer l'application
Vous pouvez laisser JAX-RS Discover les ressources ou créer une sous-classe Application
pour les enregistrer explicitement.
import jakarta.ws.rs.core.application; import java.util.set; La classe publique RestApplication étend l'application { @Outrepasser Set public <class <? >> getClasses () { Set <class <? >> Classes = new Java.util.hashSet <> (); classes.add (userresource.class); Retour des classes; } }
Ensuite, inscrivez-vous dans web.xml
(si l'utilisation):
<web-app> <Serplet> <Servlet-name> javax.ws.rs.core.application </vrlet-name> <servlet-Class> org.glassfish.jersey.servlet.servletContainer </ servlet-Class> <IniT-PARAM> <Am param-name> jakarta.ws.rs.application </onsam-name> <param-valeur> com.example.restapplication </ param-Value> </itnit-Param> <Charot-on-startup> 1 </ Load-on-Startup> </vrlet> <mappage servlet> <Servlet-name> javax.ws.rs.core.application </vrlet-name> <url-sattern> / api / * </ url-sattern> </ serflet-mapping> </ web-app>
Alternativement, les applications modernes Jakarta EE peuvent omettre web.xml
et s'appuyer sur des annotations.
4. Ajouter le support JSON (Moxy ou Jackson)
Par défaut, Jersey utilise Moxy pour la liaison JSON. Vous pouvez passer à Jackson pour plus de flexibilité:
Ajouter à pom.xml
:
<dépendance> <GroupId> org.glassfish.jersey.media </rom grouped> <ArtefactId> Jersey-Media-Json-Jackson </Retifactid> <version> 3.1.3 </ version> </Dependance>
Enregistrez ensuite le JacksonFeature
dans votre classe Application
ou via les paramètres d'initiation Web.xml.
5. Déployer et tester
Déployez votre fichier de guerre dans un conteneur Jakarta EE ou Servlet:
- HAUTONNEMENT : Utilisez la jetée intégrée ou le tomcat avec le maillot.
- Plateforme complète : Déployez sur Payara Micro , Wildfly ou Open Liberty pour les fonctionnalités complètes de Jakarta EE.
Tester avec curl
:
Curl http: // localhost: 8080 / yourApp / API / utilisateurs # Renvoie: [{"id": 1, "name": "Alice"}, {"id": 2, "name": "bob"}]
Avantages clés de Jakarta EE pour les API de repos
- Standardisé : JAX-RS est une spécification - portable entre les implémentations.
- Injection de dépendance : utilisez
@Inject
avec CDI pour une intégration de couche de service propre. - Sécurité : intégrer à Jakarta Security (
@RolesAllowed
, etc.). - Validation : utilisez la validation du bean (
@NotNull
,@Size
) sur les corps de demande. - Traitement asynchrone : Prise en charge de
AsyncResponse
pour les taches de longue date.
Exemple avec CDI:
@Path ("/ utilisateurs") @RequestScoped classe publique userresource { @Injecter UserService UserService; @OBTENIR Réponse publique getall () { return réponse.ok (userservice.getall ()). build (); } }
La construction d'API RESTful avec Jakarta EE vous donne une base mature et prête à l'entreprise. Alors que les nouveaux frameworks comme Spring Boot sont plus populaires pour les microservices, Jakarta EE reste une alternative solide et basée sur des normes - en particulier dans les environnements où la portabilité et le support à long terme sont importants.
Fondamentalement, si vous souhaitez construire des API fiables et maintenables en utilisant des normes Java officielles, Jakarta EE avec Jax-RS est un chemin éprouvé. Choisissez simplement votre runtime, définissez vos ressources et allez.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undress AI Tool
Images de déshabillage gratuites

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
échangez les visages dans n'importe quelle vidéo sans effort grace à notre outil d'échange de visage AI entièrement gratuit?!

Article chaud

Outils chauds

Bloc-notes++7.3.1
éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Maven est un outil standard pour la gestion et la construction de projet Java. La réponse réside dans le fait qu'il utilise pom.xml pour normaliser la structure du projet, la gestion des dépendances, l'automatisation du cycle de vie de la construction et les extensions de plug-in; 1. Utilisez pom.xml pour définir GroupID, Arfactive, version et dépendances; 2. Commandes Master Core telles que MvnClean, compiler, tester, package, installer et déploier; 3. Utiliser la fonction de dépendance et les exclusions pour gérer les versions et les conflits de dépendance; 4. Organisez de grandes applications via la structure du projet multi-modules et sont gérées uniformément par le POM parent; 5

Setupamaven / gradleprojectwithjax-rsDependces likejersey; 2.CreateArestResourceUsingannotationsSuchas @ pathand @ get; 3.ConfigureTheApplicationViaApplicationsUbclassorweb.xml; 4.AddjacksonforjsonBindingByCludingJersey-Media-Json-Jackson; 5.DeploEp

Tout d'abord, utilisez JavaScript pour obtenir les préférences du système utilisateur et les paramètres de thème stockés localement et initialiser le thème de la page; 1. La structure HTML contient un bouton pour déclencher la commutation du sujet; 2. CSS utilise: Root pour définir des variables de thème brillantes, la classe de mode. Dark définit les variables de thème sombres et applique ces variables via var (); 3. JavaScript détecte préfère-Color-Scheme et lit LocalStorage pour déterminer le thème initial; 4. Communiquez la classe en mode noir sur l'élément HTML lorsque vous cliquez sur le bouton et enregistre l'état actuel vers LocalStorage; 5. Tous les changements de couleur sont accompagnés d'une animation de transition de 0,3 seconde pour améliorer l'utilisateur

Comprendre les composants centraux de la blockchain, y compris les blocs, les hachages, les structures de cha?ne, les mécanismes de consensus et l'immuabilité; 2. Créez une classe de bloc qui contient des données, des horodatages, un hachage et nonce précédent, et implémentez le calcul du hachage SHA-256 et la preuve de l'exploitation de travail; 3. Construisez une classe de blockchain pour gérer les listes de blocs, initialiser le bloc Genesis, ajouter de nouveaux blocs et vérifier l'intégrité de la cha?ne; 4. écrivez la blockchain de test principal, ajoutez des blocs de données de transaction à son tour et à l'état de la cha?ne de sortie; 5. Les fonctions d'amélioration facultatives incluent la prise en charge des transactions, le réseau P2P, la signature numérique, la restapi et la persistance des données; 6. Vous pouvez utiliser des bibliothèques Java Blockchain telles que Hyperledgerfabric, Web3J ou Corda pour l'ouverture au niveau de la production

@Property Decorator est utilisé pour convertir les méthodes en propriétés pour implémenter le contr?le de lecture, de réglage et de suppression des propriétés. 1. Utilisation de base: définissez des attributs en lecture seule via @Property, tels que la zone calculée en fonction du rayon et accédé directement; 2. Utilisation avancée: utilisez @ name.setter et @ name.deleter pour implémenter les opérations de vérification et de suppression de l'attribut d'attribut; 3. Application pratique: effectuer la vérification des données dans les setters, tels que BankAccount pour s'assurer que le solde n'est pas négatif; 4. Spécification de dénomination: les variables internes sont préfixées, les noms de méthode de propriété sont cohérents avec les attributs et le contr?le d'accès unifié est utilisé pour améliorer la sécurité et la maintenabilité du code.

Pour générer des valeurs de hachage à l'aide de Java, il peut être implémenté via la classe MessagediGest. 1. Obtenez une instance de l'algorithme spécifié, tel que MD5 ou SHA-256; 2. Appelez la méthode .update () à transmettre les données à chiffrer; 3. Appelez la méthode .digest () pour obtenir un tableau d'octets de hachat; 4. Convertir le tableau d'octets en une cha?ne hexadécimale pour la lecture; Pour les entrées telles que les fichiers gros, lisez dans des morceaux et appelez .Update () plusieurs fois; Il est recommandé d'utiliser SHA-256 au lieu de MD5 ou SHA-1 pour assurer la sécurité.

Oui, un menu déroulant CSS commun peut être implémenté via Pure HTML et CSS sans JavaScript. 1. Utilisez des ul imbriqués et Li pour construire une structure de menu; 2. Utilisez le: Hover Pseudo-Class pour contr?ler l'affichage et la cachette du contenu déroulant; 3. Position définie: relative pour le parent li, et le sous-menu est positionné en utilisant la position: absolue; 4. Le sous-menu défaut par défaut: Aucun, qui devient affichage: Block lorsqu'il a survolé; 5. Le tir-down à plusieurs niveaux peut être réalisé grace à la nidification, combinée à la transition, et à l'ajout d'animations fondues, et adaptées aux terminaux mobiles avec des requêtes multimédias. La solution entière est simple et ne nécessite pas de prise en charge JavaScript, qui convient au grand

Utilisez dateTime.Strptime () pour convertir les cha?nes de date en objet DateTime. 1. Utilisation de base: Parse "2023-10-05" comme objet DateTime via "% y-% m-% d"; 2. prend en charge plusieurs formats tels que "% m /% d /% y" pour analyser les dates américaines, "% d /% m /% y" pour analyser les dates britanniques, "% b% d,% y% i:% m% p" pour analyser le temps avec AM / PM; 3. Utilisez dateUtil.parser.parse () pour déduire automatiquement les formats inconnus; 4. Utiliser .d
