0% ont trouvé ce document utile (0 vote)
14 vues13 pages

6 - Spring WS - Spring

Le document présente un cours sur la documentation API avec un accent sur la spécification OpenAPI et son intégration avec Spring Doc. Il aborde les étapes d'implémentation, de configuration et de test des Web Services à l'aide d'outils comme Swagger et Postman. Des exemples de code et des instructions pratiques sont fournis pour aider à la création et à la maintenance de la documentation API.

Transféré par

aminechnaina957
Copyright
© © All Rights Reserved
Nous prenons très au sérieux les droits relatifs au contenu. Si vous pensez qu’il s’agit de votre contenu, signalez une atteinte au droit d’auteur ici.
Formats disponibles
Téléchargez aux formats PDF, TXT ou lisez en ligne sur Scribd

Thèmes abordés

  • Documentation Technique,
  • OpenAPI Spécification,
  • Service Chambre,
  • Swagger,
  • Université,
  • Développeurs API,
  • Accès API,
  • Étudiant,
  • Mise en Place API,
  • Types de Retour
0% ont trouvé ce document utile (0 vote)
14 vues13 pages

6 - Spring WS - Spring

Le document présente un cours sur la documentation API avec un accent sur la spécification OpenAPI et son intégration avec Spring Doc. Il aborde les étapes d'implémentation, de configuration et de test des Web Services à l'aide d'outils comme Swagger et Postman. Des exemples de code et des instructions pratiques sont fournis pour aider à la création et à la maintenance de la documentation API.

Transféré par

aminechnaina957
Copyright
© © All Rights Reserved
Nous prenons très au sérieux les droits relatifs au contenu. Si vous pensez qu’il s’agit de votre contenu, signalez une atteinte au droit d’auteur ici.
Formats disponibles
Téléchargez aux formats PDF, TXT ou lisez en ligne sur Scribd

Thèmes abordés

  • Documentation Technique,
  • OpenAPI Spécification,
  • Service Chambre,
  • Swagger,
  • Université,
  • Développeurs API,
  • Accès API,
  • Étudiant,
  • Mise en Place API,
  • Types de Retour

SPRING WS – Spring Doc

Documentation API
OpenAPI Specification

© 2024-2025 – ESPRIT – Module Architecture des SI II (Spring) 1


PLAN DU COURS

– Introduction

– OpenAPI Spécification

– Implémentations

– Intégration et Configuration de Spring Doc

– TP : Exposition de tous les Web Services : Chambre (déjà fait), Bloc,


Etudiant, Foyer, Reservation, Universite

– TP : Test de tous les Web Services avec Postman et avec Swagger (Spring
Doc

© 2024-2025 – ESPRIT – Module Architecture des SI II (Spring) 2


Introduction

Que signifie la documentation API ?

C’est un manuel de référence précis qui contient les informations nécessaires pour
travailler avec l’API, notamment des détails sur les fonctions, les classes, les types
de retour et les arguments.

© 2024-2025 – ESPRIT – Module Architecture des SI II (Spring) 3


Introduction

Pourquoi ?

Les API ont pour vocation de servir à de nombreux développeurs.


Par conséquent, le développement d’une API nécessite une documentation
accessible et facilement utilisable.

Cette dernière doit toujours être à jour au fur et à mesure que le code et les
fonctionnalités de l’API évoluent.

© 2024-2025 – ESPRIT – Module Architecture des SI II (Spring) 4


OpenAPI Specification

La documentation d'un service RESTful consiste essentiellement à décrire


les détails des requêtes HTTP qu'elle consomme et des réponses HTTP qu'elle
produit.

Préparer une documentation de qualité est une tâche difficile.

Il est donc important d'utiliser des outils appropriés à cette tâche.

Les formats de description d’API tels que la spécification OpenAPI(Swagger v3)


ont permis de simplifier la création et la maintenance de la documentation.

Elle garantit également que votre documentation soit à jour au fur et à mesure de
l'évolution de votre API.

© 2024-2025 – ESPRIT – Module Architecture des SI II (Spring) 5


Implémentations

Pour l'intégration d'OAS dans notre application, nous devons faire appel à
l'implémentation qui nous convient.

Language Implémentation

Java springdoc-openapi

.Net [Link]

[Link] oas3-remote-refs

© 2024-2025 – ESPRIT – Module Architecture des SI II (Spring) 6


Intégration SpringDoc
Pour commencer, nous allons simplement ajouter la dépendance springdoc-
openapi-starter-webmvc-ui dans le fichier [Link]. Et puis faire maven update de
votre projet.

<dependency>
<groupId>[Link]</groupId>
<artifactId>springdoc-openapi-starter-webmvc-ui</artifactId>
<version>2.1.0</version>
</dependency>

C'est tout, aucune configuration supplémentaire n'est nécessaire.


La documentation sera disponible au format HTML en utilisant l'outil swagger-ui.

© 2024-2025 – ESPRIT – Module Architecture des SI II (Spring) 7


Intégration SpringDoc

Démarrer votre application Spring Boot :


Tomcat started on port(s): 8089 (http) with context path '/tpfoyer'

La page Swagger UI (Spring Doc) sera alors disponible à l’adresse:


[Link]

serveur : Le nom ou l’IP du serveur : localhost


port : Le port du serveur : 8089
context-path : Le chemin du contexte de l’application : tpfoyer :

[Link]

© 2024-2025 – ESPRIT – Module Architecture des SI II (Spring) 8


Intégration SpringDoc

© 2024-2025 – ESPRIT – Module Architecture des SI II (Spring) 9


Configuration SpringDoc
Nous pouvons aussi personnaliser la documentation grâce aux annotations:
• @Tag (@Api in swagger 2): permet d’ajouter une description pour chaque classe
RestController.
• @Operation(@ApiOperation in swagger 2): permet d’ajouter une description pour
chaque classe RestController.

@Tag(name = "Gestion Chambre")


@RestController
@AllArgsConstructor
@RequestMapping("/chambre")
public class ChambreRestController {

IChambreService chambreService;

// [Link]
@Operation(description = "récupérer toutes les chambres de la base de données")
@GetMapping("/retrieve-all-chambres")
public List<Chambre> getChambres() {
return [Link]();}

© 2024-2025 – ESPRIT – Module Architecture des SI II (Spring) 10


Configuration SpringDoc

© 2024-2025 – ESPRIT – Module Architecture des SI II (Spring) 11


Configuration SpringDoc

© 2024-2025 – ESPRIT – Module Architecture des SI II (Spring) 12


TP

Implémenter les Web Service CRUD pour toutes les


entités (Service + Controller) : Bloc, Foyer, Reservation,
Universite, Etudiant, (Chambre déjà implémentée la
semaine dernière normalement).

Utiliser Swagger (Spring Doc) et Postman pour tester les


services implémentés.

© 2024-2025 – ESPRIT – Module Architecture des SI II (Spring) 13

Vous aimerez peut-être aussi