
コーダーズ・コンカー・セキュリティ OWASP トップ 10 API シリーズ-一括割り当て
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.


大量代入の脆弱性は、多くの最新のフレームワークが、開発者がクライアントからの入力をコード変数や内部オブジェクトに自動的にバインドする関数の使用を奨励した結果生まれました。
Le Dr Matias Madou est expert en sécurité, chercheur, directeur technique et cofondateur de Secure Code Warrior. Matias a obtenu un doctorat en sécurité des applications, axé sur les solutions d'analyse statique, à l'université de Gand.Il a ensuite rejoint Fortify aux États-Unis, où il a réalisé qu'il ne suffisait pas de détecter les problèmes de code sans aider les développeurs à écrire du code sécurisé. Cela l'a amené à développer des produits qui aident les développeurs, allègent la charge de la sécurité et dépassent les attentes des clients. Lorsqu'il n'est pas à son bureau en tant que membre de Team Awesome, il apprécie de faire des présentations sur scène lors de conférences telles que RSA, BlackHat et DefCon.

Secure Code Warrior vous assiste dans la protection de votre code tout au long du cycle de vie du développement logiciel et dans la création d'une culture qui accorde la priorité à la cybersécurité. Que vous soyez responsable de la sécurité des applications, développeur, responsable de la sécurité des systèmes d'information ou professionnel de la sécurité, nous vous aidons à réduire les risques liés au code non sécurisé.
Veuillez réserver une démonstration.Le Dr Matias Madou est expert en sécurité, chercheur, directeur technique et cofondateur de Secure Code Warrior. Matias a obtenu un doctorat en sécurité des applications, axé sur les solutions d'analyse statique, à l'université de Gand.Il a ensuite rejoint Fortify aux États-Unis, où il a réalisé qu'il ne suffisait pas de détecter les problèmes de code sans aider les développeurs à écrire du code sécurisé. Cela l'a amené à développer des produits qui aident les développeurs, allègent la charge de la sécurité et dépassent les attentes des clients. Lorsqu'il n'est pas à son bureau en tant que membre de Team Awesome, il apprécie de faire des présentations sur scène lors de conférences telles que RSA, BlackHat et DefCon.
Matias est un chercheur et développeur qui possède plus de 15 ans d'expérience pratique dans le domaine de la sécurité logicielle. Il a développé des solutions pour des entreprises telles que Fortify Software et sa propre société, Sensei Security. Tout au long de sa carrière, Matias a dirigé plusieurs projets de recherche sur la sécurité des applications, qui ont abouti à la création de produits commerciaux et à l'obtention de plus de 10 brevets.Lorsqu'il n'est pas à son bureau, Matias enseigne dans le cadre de formations avancées sur la sécurité des applications et intervient régulièrement lors de conférences internationales telles que RSA Conference, Black Hat, DefCon, BSIMM, OWASP AppSec et BruCon.
Matthias a obtenu un doctorat en génie informatique à l'université de Gand, où il a étudié la sécurité des applications grâce à l'obfuscation des programmes visant à masquer le fonctionnement interne des applications.


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.

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.

Veuillez cliquer sur le lien ci-dessous pour télécharger le PDF de cette ressource.
Secure Code Warrior vous assiste dans la protection de votre code tout au long du cycle de vie du développement logiciel et dans la création d'une culture qui accorde la priorité à la cybersécurité. Que vous soyez responsable de la sécurité des applications, développeur, responsable de la sécurité des systèmes d'information ou professionnel de la sécurité, nous vous aidons à réduire les risques liés au code non sécurisé.
Afficher le rapportVeuillez réserver une démonstration.Le Dr Matias Madou est expert en sécurité, chercheur, directeur technique et cofondateur de Secure Code Warrior. Matias a obtenu un doctorat en sécurité des applications, axé sur les solutions d'analyse statique, à l'université de Gand.Il a ensuite rejoint Fortify aux États-Unis, où il a réalisé qu'il ne suffisait pas de détecter les problèmes de code sans aider les développeurs à écrire du code sécurisé. Cela l'a amené à développer des produits qui aident les développeurs, allègent la charge de la sécurité et dépassent les attentes des clients. Lorsqu'il n'est pas à son bureau en tant que membre de Team Awesome, il apprécie de faire des présentations sur scène lors de conférences telles que RSA, BlackHat et DefCon.
Matias est un chercheur et développeur qui possède plus de 15 ans d'expérience pratique dans le domaine de la sécurité logicielle. Il a développé des solutions pour des entreprises telles que Fortify Software et sa propre société, Sensei Security. Tout au long de sa carrière, Matias a dirigé plusieurs projets de recherche sur la sécurité des applications, qui ont abouti à la création de produits commerciaux et à l'obtention de plus de 10 brevets.Lorsqu'il n'est pas à son bureau, Matias enseigne dans le cadre de formations avancées sur la sécurité des applications et intervient régulièrement lors de conférences internationales telles que RSA Conference, Black Hat, DefCon, BSIMM, OWASP AppSec et BruCon.
Matthias a obtenu un doctorat en génie informatique à l'université de Gand, où il a étudié la sécurité des applications grâce à l'obfuscation des programmes visant à masquer le fonctionnement interne des applications.
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
Le Dr Matias Madou est expert en sécurité, chercheur, directeur technique et cofondateur de Secure Code Warrior. Matias a obtenu un doctorat en sécurité des applications, axé sur les solutions d'analyse statique, à l'université de Gand.Il a ensuite rejoint Fortify aux États-Unis, où il a réalisé qu'il ne suffisait pas de détecter les problèmes de code sans aider les développeurs à écrire du code sécurisé. Cela l'a amené à développer des produits qui aident les développeurs, allègent la charge de la sécurité et dépassent les attentes des clients. Lorsqu'il n'est pas à son bureau en tant que membre de Team Awesome, il apprécie de faire des présentations sur scène lors de conférences telles que RSA, BlackHat et DefCon.

Secure Code Warrior vous assiste dans la protection de votre code tout au long du cycle de vie du développement logiciel et dans la création d'une culture qui accorde la priorité à la cybersécurité. Que vous soyez responsable de la sécurité des applications, développeur, responsable de la sécurité des systèmes d'information ou professionnel de la sécurité, nous vous aidons à réduire les risques liés au code non sécurisé.
Veuillez réserver une démonstration.[Télécharger]Ressources pour débuter
Sujets et contenu de la formation sur le code sécurisé
Notre contenu, leader dans le secteur, évolue constamment en fonction de l'environnement de développement logiciel en constante mutation, tout en tenant compte du rôle de nos clients. Il couvre tous les sujets, de l'IA à l'injection XQuery, et s'adresse à divers rôles, des architectes et ingénieurs aux chefs de produit et responsables de l'assurance qualité. Nous vous invitons à consulter le catalogue de contenu pour découvrir son contenu par sujet et par rôle.
La Chambre de commerce établit la norme en matière de sécurité à grande échelle axée sur les développeurs
La Chambre de commerce néerlandaise explique comment elle a intégré le codage sécurisé dans le développement quotidien grâce à des certifications basées sur les rôles, à l'évaluation comparative du Trust Score et à une culture de responsabilité partagée en matière de sécurité.
Modélisation des menaces avec l'IA : transformer chaque développeur en modélisateur de menaces
Vous repartirez mieux équipé pour aider les développeurs à combiner les idées et les techniques de modélisation des menaces avec les outils d'IA qu'ils utilisent déjà pour renforcer la sécurité, améliorer la collaboration et créer des logiciels plus résilients dès le départ.
Ressources pour débuter
Cybermon est de retour : la mission IA consistant à vaincre le boss est désormais disponible à la demande.
Cybermon 2025 Beat the Boss est désormais disponible toute l'année sur SCW. Renforcez considérablement le développement sécurisé de l'IA en introduisant des défis de sécurité avancés en matière d'IA/LLM.
Explication de la loi sur la cyber-résilience : implications pour le développement de logiciels sécurisés dès la conception
Découvrez les exigences de la loi européenne sur la résilience cybernétique (CRA), à qui elle s'applique et comment les équipes d'ingénierie peuvent se préparer en matière de pratiques de sécurité dès la conception, de prévention des vulnérabilités et de développement des compétences des développeurs.
Facilitateur 1 : Critères de réussite prédéfinis et mesurables
Enabler 1 est le premier volet d'une série de dix intitulée « Enablers of Success » (Les catalyseurs de la réussite). Il présente comment associer le codage sécurisé à des résultats commerciaux tels que la réduction des risques et l'accélération des processus afin de faire évoluer le programme à long terme.




%20(1).avif)
.avif)
