
Découvrez le rôle stratégique des DTO dans l'optimisation des échanges de données et la performance de vos applications. Notre guide complet vous explique en détail leur définition et leurs avantages pour une architecture logicielle moderne.
C'est un objet qui rend possible le transfert des données entre les couches de l'application. Il permet de ne pas exposer les entités de la base de données et de ne pas retourner des données inutiles ou sensibles.
Il permet aussi d'avoir des requêtes HTTP plus légères.
Exemple classique : un tableau côté front :
| Nom | Prénom | |
|---|---|---|
| Doe | John | john.doe@yopmail.fr |
| Dupond | Micheal | dupond.micheal@yopmail.fr |
| Chantier | Jack | chantier.jack@yopmail.fr |
Pour construire un DTO il ne faut pas oublier que la requête SQL a aussi son importance.
this._dbContext.Utilisateurs
.Include(u => u.Adresse)
.Include(u => u.Documents)
.Include(u => u.Service)
.ToList();
ou
// chargement des jointures en mode eager
// exemple d'une mauvaise conception
this._userRepository.findAll();
ou
SELECT * FROM utilisateur
INNER JOIN adresse ON adresse.id = utilisateur.adresse_id
INNER JOIN document ON document.id = utilisateur.document_id
INNER JOIN service ON service.id = utilisateur.service_id;
Données retournées par l'APIUne API est un programme permettant à deux applications distinctes de communiquer entre elles et d’échanger des données. :
[
{
"id": 1,
"nom": "Doe",
"prenom": "John",
"email": "john.doe@yopmail.fr",
"disabled": false,
"isAdmin": true,
"password": "123456",
"service": {
"id": 1,
"nom": "Service 1"
},
"documents": [
{
"id": 1,
"nom": "Document 1"
},
{
"id": 2,
"nom": "Document 2"
}
],
"adresse": {
"id": 1,
"rue": "Rue de la paix",
"codePostal": "75000",
"ville": "Paris"
}
},
{
"id": 2,
"nom": "Dupond",
"prenom": "Micheal",
"email": "dupond.micheal.yopmail.fr",
"disabled": false,
"isAdmin": true,
"password": "123456",
"service": {
"id": 1,
"nom": "Service 1"
},
"documents": [
{
"id": 1,
"nom": "Document 1"
},
{
"id": 2,
"nom": "Document 2"
}
],
"adresse": {
"id": 1,
"rue": "Rue de la paix",
"codePostal": "75000",
"ville": "Paris"
}
},
{
"id": 3,
"nom": "Chantier",
"prenom": "Jack",
"email": "chantier.jack@yopmail.fr",
"disabled": false,
"isAdmin": true,
"password": "123456",
"service": {
"id": 1,
"nom": "Service 1"
},
"documents": [
{
"id": 1,
"nom": "Document 1"
},
{
"id": 2,
"nom": "Document 2"
}
],
"adresse": {
"id": 1,
"rue": "Rue de la paix",
"codePostal": "75000",
"ville": "Paris"
}
}
]
Dans ce cas, on peut remarquer que dans le tableau nous attendons 3 informations mais que l'API nous retourne les models avec beaucoup d'informations inutiles.
Nous ne maîtrisons pas les informations qui transitent dans notre application et de plus, ce n'est pas optimisé.
Pour résoudre ce problème, nous allons créer un DTO qui va nous permettre de retourner uniquement les informations dont nous avons besoin.
SELECT nom, prenom, email FROM utilisateur;
[
{
"nom": "Doe",
"prenom": "John",
"email": "doe.john@yopmail.fr"
},
{
"nom": "Dupond",
"prenom": "Micheal",
"email": "dupond.micheal@yopmail.fr"
},
{
"nom": "Chantier",
"prenom": "Jack",
"email": "chantier.jack@yopmail.fr"
}
]
Pour conclure il est important de maîtriser les données de bout en bout de la chaine pour les raisons suivantes :
C'est ce que les DTO permettent de faire !
Pour en savoir plus, n'hésitez pas à nous contacter, c'est par ici !
Pourquoi et comment paginer ses listes et tableaux ? Ne pas récupérer des données qui n’ont pas d’utilité immédiate. On vous explique tout !
Cet article liste les classes P5 en donnant la traduction en OJS correspondante. Etant donné le nombre important de classes dans P5 cette liste ne sera pas exhaustive mais sera enrichie au fil du temps.
Si vous êtes dans l’univers du web depuis un moment, vous avez probablement croisé le terme de Headless CMS au moins une fois ! Mais savez-vous réellement qu’est-ce qui se cache derrière un Headless CMS, comment ça fonctionne, quelles sont les différences avec un CMS classique comme Wordpress, et surtout, est-ce que ça a un intérêt à être mis en place dans un projet de site web, et plus particulièrement, pour un site web d’entreprise ? On vous partage nos retours, après plusieurs mise en prod :)