Blog

Coders Conquer Security OWASP Top 10 API Series - Affectation de masse

Matias Madou, Ph.D.
Publié le 21 octobre 2020

La vulnérabilité de l'assignation de masse est née parce que de nombreux cadres modernes encouragent les développeurs à utiliser des fonctions qui lient automatiquement les entrées des clients dans des variables de code et des objets internes. Cela permet de simplifier le code et d'accélérer les opérations.

Les attaquants peuvent utiliser cette méthode pour forcer la modification de propriétés d'objets qui ne devraient jamais être mises à jour par un client. Normalement, cela entraîne des problèmes spécifiques à l'entreprise, comme un utilisateur qui s'octroie des privilèges d'administrateur, au lieu de faire tomber un site web ou de voler des secrets d'entreprise. Les attaquants doivent également avoir une idée des relations entre les objets et la logique commerciale de l'application qu'ils exploitent.

Cependant, cela ne rend pas moins dangereuse la vulnérabilité de l'assignation de masse entre les mains d'un utilisateur intelligent et malveillant.

Avant de vous lancer dans le guide complet, jouez à notre défi ludique et voyez comment vous vous en sortez :

Comment les attaquants peuvent-ils exploiter la vulnérabilité de l'assignation de masse ?

Le scénario proposé par l'OWASP (et légèrement modifié par nos soins) suppose une application de covoiturage qui inclut différentes propriétés liées à des objets dans le code à l'aide de l'affectation de masse. Il s'agit notamment de propriétés liées aux autorisations que les utilisateurs peuvent modifier et de propriétés dépendant du processus qui ne doivent être définies qu'en interne par l'application. Toutes deux utilisent l'affectation en masse pour lier des propriétés à des objets.

Dans ce scénario, l'application de covoiturage permet aux utilisateurs de mettre à jour leur profil, comme c'est souvent le cas dans les applications destinées aux utilisateurs. Pour ce faire, elle utilise un appel API envoyé à PUT, qui renvoie l'objet JSON suivant :

{"user_name":"SneakySnake", "age":17, "is_admin":false}

Comme l'attaquant, M. SneakySnake dans ce cas, a compris la relation entre les propriétés et les objets, il peut renvoyer sa demande initiale de mise à jour de son profil avec la chaîne suivante :

{"user_name":"SneakySnake","age":24,, "is_admin":true}

Comme le point d'accès est vulnérable à l'assignation de masse, il accepte la nouvelle entrée comme étant valide. Notre pirate a non seulement ajouté quelques années à son profil, mais il s'est également attribué des privilèges d'administrateur.

Éliminer la vulnérabilité de l'assignation de masse

Bien qu'il soit pratique d'utiliser la fonction d'affectation de masse dans certains frameworks, vous devez éviter de le faire si vous voulez que vos API soient sécurisées. Au lieu de cela, analysez les valeurs de la demande au lieu de les lier directement à un objet. Vous pouvez également utiliser un objet de transfert de données réduit qui offrirait pratiquement la même commodité que la liaison directe à l'objet lui-même, mais sans le risque associé.

À titre de précaution supplémentaire, les propriétés sensibles telles que les privilèges d'administrateur de l'exemple ci-dessus peuvent être refusées afin qu'elles ne soient jamais acceptées par le serveur lors d'un appel à l'API. Une meilleure idée encore serait de refuser toutes les propriétés par défaut, puis d'autoriser des propriétés spécifiques, non sensibles, que vous souhaitez que les utilisateurs puissent mettre à jour ou modifier. L'une ou l'autre de ces mesures peut contribuer à verrouiller les API et à éliminer la vulnérabilité de l'affectation de masse dans votre environnement.

Consultez les pages du Secure Code Warrior pour en savoir plus sur cette vulnérabilité et sur la manière de protéger votre organisation et vos clients des ravages causés par d'autres failles de sécurité. Vous pouvez également essayer une démo de la plateforme de formation Secure Code Warrior pour maintenir vos compétences en cybersécurité à jour.

Voir la ressource
Voir la ressource

La vulnérabilité de l'assignation de masse est née du fait que de nombreux cadres modernes encouragent les développeurs à utiliser des fonctions qui lient automatiquement les entrées des clients dans des variables de code et des objets internes.

Vous souhaitez en savoir plus ?

Matias Madou est expert en sécurité, chercheur, directeur technique et cofondateur de Secure Code Warrior. Matias a obtenu son doctorat en sécurité des applications à l'université de Gand, en se concentrant sur les solutions d'analyse statique. Il a ensuite rejoint Fortify aux États-Unis, où il s'est rendu compte qu'il ne suffisait pas de détecter les problèmes de code sans aider les développeurs à écrire du code sécurisé. C'est ce qui l'a incité à développer des produits qui aident les développeurs, allègent le fardeau de la sécurité et dépassent les attentes des clients. Lorsqu'il n'est pas à son bureau en tant que membre de l'équipe Awesome, il aime être sur scène pour présenter des conférences, notamment RSA Conference, BlackHat et DefCon.

Secure Code Warrior est là pour vous aider à sécuriser le code tout au long du cycle de vie du développement logiciel et à créer une culture dans laquelle la cybersécurité est une priorité. Que vous soyez responsable AppSec, développeur, CISO ou toute autre personne impliquée dans la sécurité, nous pouvons aider votre organisation à réduire les risques associés à un code non sécurisé.

Réservez une démonstration
Partager sur :
Auteur
Matias Madou, Ph.D.
Publié le 21 octobre 2020

Matias Madou est expert en sécurité, chercheur, directeur technique et cofondateur de Secure Code Warrior. Matias a obtenu son doctorat en sécurité des applications à l'université de Gand, en se concentrant sur les solutions d'analyse statique. Il a ensuite rejoint Fortify aux États-Unis, où il s'est rendu compte qu'il ne suffisait pas de détecter les problèmes de code sans aider les développeurs à écrire du code sécurisé. C'est ce qui l'a incité à développer des produits qui aident les développeurs, allègent le fardeau de la sécurité et dépassent les attentes des clients. Lorsqu'il n'est pas à son bureau en tant que membre de l'équipe Awesome, il aime être sur scène pour présenter des conférences, notamment RSA Conference, BlackHat et DefCon.

Matias est un chercheur et un développeur qui possède plus de 15 ans d'expérience pratique dans le domaine de la sécurité des logiciels. Il a développé des solutions pour des entreprises telles que Fortify Software et sa propre entreprise Sensei Security. Au cours de sa carrière, Matias a dirigé de nombreux projets de recherche sur la sécurité des applications qui ont débouché sur des produits commerciaux et peut se targuer d'avoir déposé plus de 10 brevets. Lorsqu'il n'est pas à son bureau, Matias a été instructeur pour des formations avancées en matière de sécurité des applications ( courses ) et intervient régulièrement lors de conférences mondiales telles que RSA Conference, Black Hat, DefCon, BSIMM, OWASP AppSec et BruCon.

Matias est titulaire d'un doctorat en ingénierie informatique de l'Université de Gand, où il a étudié la sécurité des applications par le biais de l'obscurcissement des programmes afin de dissimuler le fonctionnement interne d'une application.

Partager sur :

La vulnérabilité de l'assignation de masse est née parce que de nombreux cadres modernes encouragent les développeurs à utiliser des fonctions qui lient automatiquement les entrées des clients dans des variables de code et des objets internes. Cela permet de simplifier le code et d'accélérer les opérations.

Les attaquants peuvent utiliser cette méthode pour forcer la modification de propriétés d'objets qui ne devraient jamais être mises à jour par un client. Normalement, cela entraîne des problèmes spécifiques à l'entreprise, comme un utilisateur qui s'octroie des privilèges d'administrateur, au lieu de faire tomber un site web ou de voler des secrets d'entreprise. Les attaquants doivent également avoir une idée des relations entre les objets et la logique commerciale de l'application qu'ils exploitent.

Cependant, cela ne rend pas moins dangereuse la vulnérabilité de l'assignation de masse entre les mains d'un utilisateur intelligent et malveillant.

Avant de vous lancer dans le guide complet, jouez à notre défi ludique et voyez comment vous vous en sortez :

Comment les attaquants peuvent-ils exploiter la vulnérabilité de l'assignation de masse ?

Le scénario proposé par l'OWASP (et légèrement modifié par nos soins) suppose une application de covoiturage qui inclut différentes propriétés liées à des objets dans le code à l'aide de l'affectation de masse. Il s'agit notamment de propriétés liées aux autorisations que les utilisateurs peuvent modifier et de propriétés dépendant du processus qui ne doivent être définies qu'en interne par l'application. Toutes deux utilisent l'affectation en masse pour lier des propriétés à des objets.

Dans ce scénario, l'application de covoiturage permet aux utilisateurs de mettre à jour leur profil, comme c'est souvent le cas dans les applications destinées aux utilisateurs. Pour ce faire, elle utilise un appel API envoyé à PUT, qui renvoie l'objet JSON suivant :

{"user_name":"SneakySnake", "age":17, "is_admin":false}

Comme l'attaquant, M. SneakySnake dans ce cas, a compris la relation entre les propriétés et les objets, il peut renvoyer sa demande initiale de mise à jour de son profil avec la chaîne suivante :

{"user_name":"SneakySnake","age":24,, "is_admin":true}

Comme le point d'accès est vulnérable à l'assignation de masse, il accepte la nouvelle entrée comme étant valide. Notre pirate a non seulement ajouté quelques années à son profil, mais il s'est également attribué des privilèges d'administrateur.

Éliminer la vulnérabilité de l'assignation de masse

Bien qu'il soit pratique d'utiliser la fonction d'affectation de masse dans certains frameworks, vous devez éviter de le faire si vous voulez que vos API soient sécurisées. Au lieu de cela, analysez les valeurs de la demande au lieu de les lier directement à un objet. Vous pouvez également utiliser un objet de transfert de données réduit qui offrirait pratiquement la même commodité que la liaison directe à l'objet lui-même, mais sans le risque associé.

À titre de précaution supplémentaire, les propriétés sensibles telles que les privilèges d'administrateur de l'exemple ci-dessus peuvent être refusées afin qu'elles ne soient jamais acceptées par le serveur lors d'un appel à l'API. Une meilleure idée encore serait de refuser toutes les propriétés par défaut, puis d'autoriser des propriétés spécifiques, non sensibles, que vous souhaitez que les utilisateurs puissent mettre à jour ou modifier. L'une ou l'autre de ces mesures peut contribuer à verrouiller les API et à éliminer la vulnérabilité de l'affectation de masse dans votre environnement.

Consultez les pages du Secure Code Warrior pour en savoir plus sur cette vulnérabilité et sur la manière de protéger votre organisation et vos clients des ravages causés par d'autres failles de sécurité. Vous pouvez également essayer une démo de la plateforme de formation Secure Code Warrior pour maintenir vos compétences en cybersécurité à jour.

Voir la ressource
Voir la ressource

Remplissez le formulaire ci-dessous pour télécharger le rapport

Nous aimerions que vous nous autorisiez à vous envoyer des informations sur nos produits et/ou sur des sujets liés au codage sécurisé. Nous traiterons toujours vos données personnelles avec le plus grand soin et ne les vendrons jamais à d'autres entreprises à des fins de marketing.

Soumettre
Pour soumettre le formulaire, veuillez activer les cookies "Analytics". N'hésitez pas à les désactiver à nouveau une fois que vous aurez terminé.

La vulnérabilité de l'assignation de masse est née parce que de nombreux cadres modernes encouragent les développeurs à utiliser des fonctions qui lient automatiquement les entrées des clients dans des variables de code et des objets internes. Cela permet de simplifier le code et d'accélérer les opérations.

Les attaquants peuvent utiliser cette méthode pour forcer la modification de propriétés d'objets qui ne devraient jamais être mises à jour par un client. Normalement, cela entraîne des problèmes spécifiques à l'entreprise, comme un utilisateur qui s'octroie des privilèges d'administrateur, au lieu de faire tomber un site web ou de voler des secrets d'entreprise. Les attaquants doivent également avoir une idée des relations entre les objets et la logique commerciale de l'application qu'ils exploitent.

Cependant, cela ne rend pas moins dangereuse la vulnérabilité de l'assignation de masse entre les mains d'un utilisateur intelligent et malveillant.

Avant de vous lancer dans le guide complet, jouez à notre défi ludique et voyez comment vous vous en sortez :

Comment les attaquants peuvent-ils exploiter la vulnérabilité de l'assignation de masse ?

Le scénario proposé par l'OWASP (et légèrement modifié par nos soins) suppose une application de covoiturage qui inclut différentes propriétés liées à des objets dans le code à l'aide de l'affectation de masse. Il s'agit notamment de propriétés liées aux autorisations que les utilisateurs peuvent modifier et de propriétés dépendant du processus qui ne doivent être définies qu'en interne par l'application. Toutes deux utilisent l'affectation en masse pour lier des propriétés à des objets.

Dans ce scénario, l'application de covoiturage permet aux utilisateurs de mettre à jour leur profil, comme c'est souvent le cas dans les applications destinées aux utilisateurs. Pour ce faire, elle utilise un appel API envoyé à PUT, qui renvoie l'objet JSON suivant :

{"user_name":"SneakySnake", "age":17, "is_admin":false}

Comme l'attaquant, M. SneakySnake dans ce cas, a compris la relation entre les propriétés et les objets, il peut renvoyer sa demande initiale de mise à jour de son profil avec la chaîne suivante :

{"user_name":"SneakySnake","age":24,, "is_admin":true}

Comme le point d'accès est vulnérable à l'assignation de masse, il accepte la nouvelle entrée comme étant valide. Notre pirate a non seulement ajouté quelques années à son profil, mais il s'est également attribué des privilèges d'administrateur.

Éliminer la vulnérabilité de l'assignation de masse

Bien qu'il soit pratique d'utiliser la fonction d'affectation de masse dans certains frameworks, vous devez éviter de le faire si vous voulez que vos API soient sécurisées. Au lieu de cela, analysez les valeurs de la demande au lieu de les lier directement à un objet. Vous pouvez également utiliser un objet de transfert de données réduit qui offrirait pratiquement la même commodité que la liaison directe à l'objet lui-même, mais sans le risque associé.

À titre de précaution supplémentaire, les propriétés sensibles telles que les privilèges d'administrateur de l'exemple ci-dessus peuvent être refusées afin qu'elles ne soient jamais acceptées par le serveur lors d'un appel à l'API. Une meilleure idée encore serait de refuser toutes les propriétés par défaut, puis d'autoriser des propriétés spécifiques, non sensibles, que vous souhaitez que les utilisateurs puissent mettre à jour ou modifier. L'une ou l'autre de ces mesures peut contribuer à verrouiller les API et à éliminer la vulnérabilité de l'affectation de masse dans votre environnement.

Consultez les pages du Secure Code Warrior pour en savoir plus sur cette vulnérabilité et sur la manière de protéger votre organisation et vos clients des ravages causés par d'autres failles de sécurité. Vous pouvez également essayer une démo de la plateforme de formation Secure Code Warrior pour maintenir vos compétences en cybersécurité à jour.

Accès aux ressources

Cliquez sur le lien ci-dessous et téléchargez le PDF de cette ressource.

Secure Code Warrior est là pour vous aider à sécuriser le code tout au long du cycle de vie du développement logiciel et à créer une culture dans laquelle la cybersécurité est une priorité. Que vous soyez responsable AppSec, développeur, CISO ou toute autre personne impliquée dans la sécurité, nous pouvons aider votre organisation à réduire les risques associés à un code non sécurisé.

Voir le rapportRéservez une démonstration
Partager sur :
Vous souhaitez en savoir plus ?

Partager sur :
Auteur
Matias Madou, Ph.D.
Publié le 21 octobre 2020

Matias Madou est expert en sécurité, chercheur, directeur technique et cofondateur de Secure Code Warrior. Matias a obtenu son doctorat en sécurité des applications à l'université de Gand, en se concentrant sur les solutions d'analyse statique. Il a ensuite rejoint Fortify aux États-Unis, où il s'est rendu compte qu'il ne suffisait pas de détecter les problèmes de code sans aider les développeurs à écrire du code sécurisé. C'est ce qui l'a incité à développer des produits qui aident les développeurs, allègent le fardeau de la sécurité et dépassent les attentes des clients. Lorsqu'il n'est pas à son bureau en tant que membre de l'équipe Awesome, il aime être sur scène pour présenter des conférences, notamment RSA Conference, BlackHat et DefCon.

Matias est un chercheur et un développeur qui possède plus de 15 ans d'expérience pratique dans le domaine de la sécurité des logiciels. Il a développé des solutions pour des entreprises telles que Fortify Software et sa propre entreprise Sensei Security. Au cours de sa carrière, Matias a dirigé de nombreux projets de recherche sur la sécurité des applications qui ont débouché sur des produits commerciaux et peut se targuer d'avoir déposé plus de 10 brevets. Lorsqu'il n'est pas à son bureau, Matias a été instructeur pour des formations avancées en matière de sécurité des applications ( courses ) et intervient régulièrement lors de conférences mondiales telles que RSA Conference, Black Hat, DefCon, BSIMM, OWASP AppSec et BruCon.

Matias est titulaire d'un doctorat en ingénierie informatique de l'Université de Gand, où il a étudié la sécurité des applications par le biais de l'obscurcissement des programmes afin de dissimuler le fonctionnement interne d'une application.

Partager sur :

La vulnérabilité de l'assignation de masse est née parce que de nombreux cadres modernes encouragent les développeurs à utiliser des fonctions qui lient automatiquement les entrées des clients dans des variables de code et des objets internes. Cela permet de simplifier le code et d'accélérer les opérations.

Les attaquants peuvent utiliser cette méthode pour forcer la modification de propriétés d'objets qui ne devraient jamais être mises à jour par un client. Normalement, cela entraîne des problèmes spécifiques à l'entreprise, comme un utilisateur qui s'octroie des privilèges d'administrateur, au lieu de faire tomber un site web ou de voler des secrets d'entreprise. Les attaquants doivent également avoir une idée des relations entre les objets et la logique commerciale de l'application qu'ils exploitent.

Cependant, cela ne rend pas moins dangereuse la vulnérabilité de l'assignation de masse entre les mains d'un utilisateur intelligent et malveillant.

Avant de vous lancer dans le guide complet, jouez à notre défi ludique et voyez comment vous vous en sortez :

Comment les attaquants peuvent-ils exploiter la vulnérabilité de l'assignation de masse ?

Le scénario proposé par l'OWASP (et légèrement modifié par nos soins) suppose une application de covoiturage qui inclut différentes propriétés liées à des objets dans le code à l'aide de l'affectation de masse. Il s'agit notamment de propriétés liées aux autorisations que les utilisateurs peuvent modifier et de propriétés dépendant du processus qui ne doivent être définies qu'en interne par l'application. Toutes deux utilisent l'affectation en masse pour lier des propriétés à des objets.

Dans ce scénario, l'application de covoiturage permet aux utilisateurs de mettre à jour leur profil, comme c'est souvent le cas dans les applications destinées aux utilisateurs. Pour ce faire, elle utilise un appel API envoyé à PUT, qui renvoie l'objet JSON suivant :

{"user_name":"SneakySnake", "age":17, "is_admin":false}

Comme l'attaquant, M. SneakySnake dans ce cas, a compris la relation entre les propriétés et les objets, il peut renvoyer sa demande initiale de mise à jour de son profil avec la chaîne suivante :

{"user_name":"SneakySnake","age":24,, "is_admin":true}

Comme le point d'accès est vulnérable à l'assignation de masse, il accepte la nouvelle entrée comme étant valide. Notre pirate a non seulement ajouté quelques années à son profil, mais il s'est également attribué des privilèges d'administrateur.

Éliminer la vulnérabilité de l'assignation de masse

Bien qu'il soit pratique d'utiliser la fonction d'affectation de masse dans certains frameworks, vous devez éviter de le faire si vous voulez que vos API soient sécurisées. Au lieu de cela, analysez les valeurs de la demande au lieu de les lier directement à un objet. Vous pouvez également utiliser un objet de transfert de données réduit qui offrirait pratiquement la même commodité que la liaison directe à l'objet lui-même, mais sans le risque associé.

À titre de précaution supplémentaire, les propriétés sensibles telles que les privilèges d'administrateur de l'exemple ci-dessus peuvent être refusées afin qu'elles ne soient jamais acceptées par le serveur lors d'un appel à l'API. Une meilleure idée encore serait de refuser toutes les propriétés par défaut, puis d'autoriser des propriétés spécifiques, non sensibles, que vous souhaitez que les utilisateurs puissent mettre à jour ou modifier. L'une ou l'autre de ces mesures peut contribuer à verrouiller les API et à éliminer la vulnérabilité de l'affectation de masse dans votre environnement.

Consultez les pages du Secure Code Warrior pour en savoir plus sur cette vulnérabilité et sur la manière de protéger votre organisation et vos clients des ravages causés par d'autres failles de sécurité. Vous pouvez également essayer une démo de la plateforme de formation Secure Code Warrior pour maintenir vos compétences en cybersécurité à jour.

Table des matières

Voir la ressource
Vous souhaitez en savoir plus ?

Matias Madou est expert en sécurité, chercheur, directeur technique et cofondateur de Secure Code Warrior. Matias a obtenu son doctorat en sécurité des applications à l'université de Gand, en se concentrant sur les solutions d'analyse statique. Il a ensuite rejoint Fortify aux États-Unis, où il s'est rendu compte qu'il ne suffisait pas de détecter les problèmes de code sans aider les développeurs à écrire du code sécurisé. C'est ce qui l'a incité à développer des produits qui aident les développeurs, allègent le fardeau de la sécurité et dépassent les attentes des clients. Lorsqu'il n'est pas à son bureau en tant que membre de l'équipe Awesome, il aime être sur scène pour présenter des conférences, notamment RSA Conference, BlackHat et DefCon.

Secure Code Warrior est là pour vous aider à sécuriser le code tout au long du cycle de vie du développement logiciel et à créer une culture dans laquelle la cybersécurité est une priorité. Que vous soyez responsable AppSec, développeur, CISO ou toute autre personne impliquée dans la sécurité, nous pouvons aider votre organisation à réduire les risques associés à un code non sécurisé.

Réservez une démonstrationTélécharger
Partager sur :
Centre de ressources

Ressources pour vous aider à démarrer

Plus d'articles
Centre de ressources

Ressources pour vous aider à démarrer

Plus d'articles