Table des matières
Utilisez une configuration de moteur à modèle sécurisé
Évitez d'utiliser la saisie de l'utilisateur comme contenu de modèle
Rendre des modèles d'utilisateurs à l'aide de bacs de sable ou d'environnements isolés
Revoir régulièrement comment les modèles sont utilisés et les versions dépendantes
Maison Java javaDidacticiel Sécurité Java pour l'injection de modèle côté serveur

Sécurité Java pour l'injection de modèle côté serveur

Jul 16, 2025 am 01:15 AM
java

La prévention de l'injection de modèle côté serveur (SSTI) nécessite quatre aspects: 1. Utilisez des configurations de sécurité, telles que la désactivation des appels de méthode et la restriction de la charge de classe; 2. Évitez l'entrée de l'utilisateur comme contenu de modèle, seul remplacement variable et vérifiez strictement l'entrée; 3. Adopter des environnements de bac à sable, tels que le galet, la moustache ou l'isolement du contexte de rendu; 4. Mettez régulièrement à jour la version dépendante et examinez la logique de code pour vous assurer que le moteur de modèle est configuré raisonnablement et empêcher le système d'être attaqué en raison de modèles contrôlables par l'utilisateur.

Sécurité Java pour l'injection de modèle côté serveur

L'injection de modèle côté serveur (SSTI) est un problème de sécurité qui est facilement négligé mais présente un risque potentiel très élevé dans les applications Java. Le moteur de modèle est initialement destiné à faciliter les développeurs de générer plus facilement du contenu dynamique, mais s'il est utilisé mal, l'attaquant peut exécuter du code arbitraire par l'injection de modèle, ce qui conduit directement au contrôle du système. Bien que Java ne déclenche pas facilement SSTI comme Python ou PHP, les conséquences seront tout aussi graves en cas de problème.

Sécurité Java pour l'injection de modèle côté serveur

Ce qui suit est quelques perspectives communes pour parler de la façon d'empêcher SSTI dans les projets Java.


Utilisez une configuration de moteur à modèle sécurisé

De nombreux moteurs de modèle permettent l'exécution de l'expression par défaut, comme le thymeleaf, le freariker et la vitesse. Si ces moteurs n'ont pas de restrictions, ils deviendront facilement l'entrée de SSTI.

Sécurité Java pour l'injection de modèle côté serveur

Prenez un exemple Freemarker. Par défaut, il permet d'appeler des méthodes Java, telles que ${'abc'.getClass().getName()} pour obtenir le nom de classe et exécuter davantage le code arbitraire. Pour éviter cela, vous pouvez:

  • Désactiver les appels de la méthode: cfg.setMethodExposureLevel(Configuration.MethodExposure.LIMITED);
  • Désactiver le chargement du modèle de classe: Évitez la saisie de l'utilisateur comme contenu de modèle
  • Définissez un mécanisme de liste blanche pour limiter les classes et méthodes accessibles

De même, Thymeleaf a des appels de méthode désactivés dans les expressions par défaut en commençant par 3.0, mais il est toujours recommandé de vérifier la configuration pour s'assurer que les fonctionnalités à haut risque de SpringEL ne sont pas activées.

Sécurité Java pour l'injection de modèle côté serveur

Évitez d'utiliser la saisie de l'utilisateur comme contenu de modèle

Le problème central de SSTI est que le contenu du modèle est contrôlable. Si votre application permet aux utilisateurs de saisir un texte et de le rendre comme un modèle, c'est presque comme ouvrir la porte aux voleurs.

Par exemple, certains systèmes permettent aux utilisateurs de personnaliser les modèles de messagerie, le contenu de la page, etc. Si ces contenus sont directement remis au moteur de modèle pour le traitement, il est facile d'être injecté dans des expressions malveillantes.

suggestion:

  • Ne laissez pas les utilisateurs contrôler la structure du modèle, seul le remplacement variable est autorisé
  • Si vous devez laisser l'utilisateur modifier le modèle, envisagez d'utiliser des variables de liste blanche ou rendez-vous avec un environnement de bac à sable
  • Échappement strict de la somme de contrôle de la saisie de l'utilisateur, en particulier des caractères spéciaux tels que ${} , #{} , etc.

Rendre des modèles d'utilisateurs à l'aide de bacs de sable ou d'environnements isolés

Si votre application nécessite des modèles définis par l'utilisateur, envisagez d'utiliser des moteurs de modèles de sable ou d'isoler le risque en limitant le contexte.

Par exemple:

  • En utilisant Pebble , il n'exécute pas les appels de méthode arbitraire par défaut
  • En utilisant la moustache , il s'agit d'un langage de modèle logiquement indépendant et n'est pas facile de déclencher SSTI
  • Pour la vitesse, vous pouvez hériter de EventCartridge pour limiter le comportement du modèle

De plus, vous pouvez également envisager d'exécuter le rendu du modèle d'utilisateur dans un JVM ou un conteneur séparé, restreignant ses autorisations, telles que le non-chargement de classes sensibles, l'interdiction de la réflexion, etc.


Revoir régulièrement comment les modèles sont utilisés et les versions dépendantes

Le moteur de modèle lui-même peut également avoir des vulnérabilités de sécurité, telles que les CVE liés à SSTI qui sont apparus dans des versions plus anciennes de la liaison libre ou de la vitesse.

suggestion:

  • Gardez les dépendances du moteur à jour avec la dernière version stable
  • Analyser les dépendances du projet à l'aide de la dépendance OWASP ou des outils similaires
  • Passez en revue la façon dont les appels du modèle dans le code pour éviter d'utiliser une logique d' eval

En général, bien que SSTI en Java ne soit pas aussi courant que les autres langues, il ne peut pas être pris à la légère. Le point clé est: ne laissez pas les utilisateurs contrôler le contenu du modèle, configurez raisonnablement le moteur de modèle et utilisez l'environnement de bac à sable si nécessaire. Fondamentalement, tout cela, les problèmes de sécurité ne sont souvent pas très compliqués, mais sont facilement négligés.

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!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Porce de variable PHP expliquée
1 Il y a quelques mois By 百草
Commentant le code en php
4 Il y a quelques semaines By 百草
Conseils pour écrire des commentaires PHP
4 Il y a quelques semaines By 百草
<🎜>: Grow A Garden - Guide complet des marchands itinérants
3 Il y a quelques semaines By Jack chen

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

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

Sujets chauds

Tutoriel PHP
1510
276
Correction: la mise à jour Windows n'a pas réussi à installer Correction: la mise à jour Windows n'a pas réussi à installer Aug 08, 2025 pm 04:16 PM

RunThewindowsUpDateTroulesshooTervAyingSettings> Update & Security> TroubleshoottoAutomAticyFixComMonissues.2.ResetwindowsupDateComponentsBystoppingrelatedServices, RenamingtheSoftwaredSistributeandCatroot2folders, TherestartingTheServicestoClelele

Comment utiliser une boucle de temps en Java Comment utiliser une boucle de temps en Java Aug 08, 2025 pm 04:04 PM

AwhileloopinjavarePeatlyExECUtesCodeaslongAstheConditioniStrue; 2.InitialiseAntrolvariableBeforeTheroop; 3.DefeTheLoopConditionususingAboolEanExpression; 4.UpdateTheControlvariableSideThelopToPrevevenInIniteLooping; 5.USEEXMELLESLILESLINIDINGNUNTINGNUMBUR

Quel est le processus de sérialisation pour un objet Java? Quel est le processus de sérialisation pour un objet Java? Aug 08, 2025 pm 04:03 PM

JavaserializationConvertsanObject'sStateIntoabyTereamForSorageorTransmission, etdesializationreconstructStheObjectfromThatStream.1.ToEnableSerialization, aclassmustimplementTheSerizable Interface.2.UseObjectOutStreamToserialiseanobject, Savin

Qu'est-ce qu'un hashmap à Java? Qu'est-ce qu'un hashmap à Java? Aug 11, 2025 pm 07:24 PM

AhashmapinjavaisadatastructureThatStoreskey-ValuepraireForeFICETTREVAL, insertion etdeletion.itUshesthekey’shashcode () methodtodeterMinestorageLocationandallowsAtEptoro (1) timeComplexityforget () andput () opérations.

Comment créer et utiliser un tableau en java Comment créer et utiliser un tableau en java Aug 11, 2025 pm 04:00 PM

TOCREATANDUSEAnArrayinjava, FirstdeclatethearraywithThedatatypeAndSquarebrackets, ThenstantiateitwithThenewKeywordOralitializeTirectlywithValues; 1.DeclareAndedCreateArrayusingDataty

Comment créez-vous un fil en Java? Comment créez-vous un fil en Java? Aug 11, 2025 pm 01:34 PM

YoucancreatEatheadInjavabyExtentenstenstheredClassorimpelementingTherUnableInterface.2.ExtendingThreadInvolvesCreatAclassHatoverrideStherun () MethodandCallingStart () onaninstance.3.ImplementsrunnableRequireSdefiningTherun () Methodinaclasse.30

Python Argparse exigence de l'argument requis Python Argparse exigence de l'argument requis Aug 11, 2025 pm 09:42 PM

Lorsque vous utilisez le module ArgParse, les paramètres qui doivent être fournis peuvent être obtenus en réglant le réglage = TRUE. 1. Utiliser requis = TRUE pour définir des paramètres facultatifs (tels que --inter) à être requis. S'il n'est pas fourni lors de l'exécution du script, une erreur sera signalée; 2. Les paramètres de position sont requis par défaut, et il n'est pas nécessaire de définir requis = true; 3. Il est recommandé d'utiliser les paramètres de position pour les paramètres nécessaires. Parfois, les paramètres facultatifs de requis = TRUE sont utilisés pour maintenir la flexibilité; 4. Required = true est le moyen le plus direct de contrôler les paramètres. Après utilisation, l'utilisateur doit fournir des paramètres correspondants lors de l'appel du script, sinon le programme invitera une erreur et quittera.

Comment utiliser un ensemble en Java Comment utiliser un ensemble en Java Aug 11, 2025 am 11:57 AM

ChooseTheAppropriateSeTIMPLIMENTATION: useHashSetForFastOperations avec Order, LinkedHashSetForInSertionOrder, andtreeSetForsorDes

See all articles