Frage Thymeleaf -> Fehler ignorieren und mit "" ersetzen?

internet

Top Contributor
Ich habe länger im Internet nachgeschaut, aber finde leider keine Lösung...

Ich habe einen HTML Text als String, den mein User definieren kann.
Daher habe ich auch nicht 100% einen Einfluss, wie dieser HTML String aussieht.
Bevor ich die Verarbeitung mit Thymeleaf starte, parse ich erstmal alle Variablen mir in eine Liste.
Anschließend erstelle ich mir den Context und speichere dort die Variablen:

Code:
Context context = new Context();
context.setVariable("customer.", customer);

Nun habe ich einige Variablen innerhalb dem String. Manchmal gibt es aber Variablen, die nicht gefunden werden oder richtig aufgelöst werden können von Thymeleaf.
Eine Exception von Thymeleaf könnte ich fangen, allerdings wird der String nicht weiterverarbeitet um die Variablen zu ersetzen.

Wie schaffe ich es, dass die Variablen, die ein Fehler in Thymeleaf einfach entweder
a) Nicht ersetzt werden
oder
b) mit einem "" ersetzt werden?

Code:
public class Test {

    public static void main(String[] args) {

        // Erstelle einen String-Template-Resolver
        StringTemplateResolver templateResolver = new StringTemplateResolver();
        templateResolver.setTemplateMode(TemplateMode.HTML);

        // Logging ausstellen
        Logger thymeleafLogger = (Logger) LoggerFactory.getLogger("org.thymeleaf");
        thymeleafLogger.setLevel(Level.OFF);

        // Erstelle eine Template-Engine
        TemplateEngine templateEngine = new TemplateEngine();
        templateEngine.setTemplateResolver(templateResolver);

        // Deaktivieren Sie den Debug-Modus

        // Definiere den Template-String
//        String templateString = "<p>Hello, [[${name}]]!</p>";
        String templateString = "<p>Hello, {{jobSharingCompany..id}} !</p>";

        JobSharingCompanyDTO jobSharingCompany = new JobSharingCompanyDTO();
        jobSharingCompany.setId("1");
//        ObjectForReplacementObject replacementObject = new ObjectForReplacementObject();
//        PlaceholderFunctions.replaceObject(templateString, "customer.name", customer.getName(), replacementObject);

        // Erstelle einen Kontext mit den Variablen
        Context context = new Context();
//        context.setVariables(replacementObject.getReplacementVariableList());
        context.setVariable("jobSharingCompany.", jobSharingCompany);

        // Ersetze benutzerdefinierte Variablen-Syntax durch Standard-Syntax
        templateString = replaceCustomVariableSyntax(templateString);

        // Prozessiere das Template mit den Variablen
        StringWriter stringWriter = new StringWriter();

//        try {
            templateEngine.process(templateString, context, stringWriter);
//        } catch (Exception e) {
//            // Catch any exceptions and return an empty string
//        }

        // Gib das resultierende HTML aus
        System.out.println(stringWriter.toString());
    }

    // Methode zum Ersetzen der benutzerdefinierten Variablen-Syntax durch
    // Standard-Syntax
    private static String replaceCustomVariableSyntax(String templateString) {
        String output = templateString.replaceAll("\\{\\{([^}]+)\\}\\}", "[[\\${$1}]]");
        return output;
    }

}

Nun bekomme ich eben diese Exception:
Caused by: org.attoparser.ParseException: Exception evaluating OGNL expression: "jobSharingCompany..id" (template: "<p>Hello, [[${jobSharingCompany..id}]] !</p>" - line 1, col 13)
Nun sollte einfach das herauskommen:
Hello, !</p>

Wenn ich die Exception fange, erhalte ich aber:
Hello,

Also sprich der nachfolgende Text wird nicht mehr weiter verarbeitet...

Wie kann ich das lösen?
Gibt es eine Einstellung mit der ich die Fehler ignorieren kann?

Danke für die Hilfe
 

Oneixee5

Top Contributor
Das habe ich im anderen Post schon gezeigt:
<p>Hello, <span th:text="${session.user.name}">Karl</span>!</p> hier ist Karl der Default.

Außerdem ist hier ein Fehler drin: {{jobSharingCompany..id}} - es gehört nur ein . da rein
 

internet

Top Contributor
Außerdem ist hier ein Fehler drin: {{jobSharingCompany..id}} - es gehört nur ein . da rein
Das ist doch gerade das Problem...
1. Mein User definiert einen HTML Code und hat ein Fehler gemacht, statt: bpsw. {{jobSharingCompany.id}} macht er einen Punkt zu viel: {{jobSharingCompany..id}}

2. Nun startet der Prozess von Thymeleaf
3. Beim Ersetzen von {{jobSharingCompany..id}} schmeißt Thymeleaf aber nun einen Fehler und der ganze Prozess für das Ersetzen der Platzhalter wird abgebrochen

Was ich nun aber erreichen möchte ist, dass das Programm weiterläuft und eben die fehlgeschlagenen / nicht gefundene Platzhalter einfach mit einem leeren String ersetzt werden.

Wie erreiche ich das?
 

internet

Top Contributor
Also vllt mal um klarzustellen: ich will es nicht verwenden um eine Webseite zu bauen. Ich will dadurch
A) PDF Dokument erstellen
B) Emailtext erstellen

Inwiefern hast du Bedenken, dass das eine Sicherheitslücke ist?
 

Oneixee5

Top Contributor
Also vllt mal um klarzustellen: ich will es nicht verwenden um eine Webseite zu bauen. Ich will dadurch
A) PDF Dokument erstellen
B) Emailtext erstellen

Inwiefern hast du Bedenken, dass das eine Sicherheitslücke ist?
Man baut als Kunde in sein Template:
{{jobSharingCompany.costomers.jobSharingCompanys }}
Schon kenne ich alle Kunden-Unternehmen, bei welchen meine Kunden möglicherweise auch noch Arbeitskräfte mieten. Mal abgesehen davon ob man hier noch eine Schleife bräuchte. Man hangelt sich einfach durch die Objektstruktur und schaut mal was so rauspurzelt. Mit {{jobSharingCompany}} sieht man ja schon mal das ganze Objekt, wenn z.B. #toString() überschrieben ist.
 

internet

Top Contributor
Man baut als Kunde in sein Template:
{{jobSharingCompany.costomers.jobSharingCompanys }}
Schon kenne ich alle Kunden-Unternehmen, bei welchen meine Kunden möglicherweise auch noch Arbeitskräfte mieten.
Aber dazu müsste doch "jobSharingCompany" erstmal die Property "costomers" haben?
jobSharingCompany ist eine DTO Klasse, somit gebe ich ja auch nur Informationen aus, die der User auch per API sehen würde
 

mrBrown

Super-Moderator
Mitarbeiter
Inwiefern hast du Bedenken, dass das eine Sicherheitslücke ist?
Wenn Nutzer Methoden ausführen können ist das immer eine Sicherheitslücke, außer du kannst ziemlich eng über Allowlists definieren, was aufgerufen werden kann.

Thymeleaf scheint OGNL zu verwendet, und da scheinen statische Methoden nutzbar zu sein, möglich wäre dann vielleicht sowas: @java.lang.Runtime@getRuntime().exec(new String[] { "/bin/sh" }) (keine Ahnung ob die Syntax so passt oder das irgendwie verhindert wird)
 

LimDul

Top Contributor
https://book.hacktricks.xyz/pentesting-web/ssti-server-side-template-injection - mal zu Thymeleaf scrollen, da stehen ein paar Beispiele

However, the likelihood of this payload working is generally low. Thymeleaf's default configuration doesn't support dynamic template generation; templates must be predefined. Developers would need to implement their own TemplateResolver to create templates from strings on-the-fly, which is uncommon.

Hmmm ...

(...)
Code:
public class Test {

    public static void main(String[] args) {

        // Erstelle einen String-Template-Resolver
        StringTemplateResolver templateResolver = new StringTemplateResolver();
 

internet

Top Contributor
Aktuell sehe ich nur die Möglichkeit:
  • Alle Platzhalter aus dem String herausparsen
  • Jeden einzelnen Platzhalter validieren. Wenn kein Fehler, dann ersetzen. Wenn Fehler, dann mit "" ersetzen.

Wäre eben einige Male die auszuführen:
Java:
templateEngine.process(templateString, context, stringWriter);
 

internet

Top Contributor

internet

Top Contributor
Aber ich denke ich brauche hier sicherlich eine Whitelist....
Bspw. das würde funktionieren:

Java:
{{jobSharingCompany.getClass()}}
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
I Frage Thymeleaf -> Prefix / Suffix ändern? Java Basics - Anfänger-Themen 11
Zrebna Frage zu Test-Driven Development (TDD) Java Basics - Anfänger-Themen 3
D Rekursions Probleme / frage Java Basics - Anfänger-Themen 4
T Frage zu Parse Java Basics - Anfänger-Themen 2
H Frage an die Profis Java Basics - Anfänger-Themen 4
J Eine konzeptionelle Frage zu OOP Java Basics - Anfänger-Themen 3
P Frage zu Rekursion und Backtracking Java Basics - Anfänger-Themen 2
H Frage zur Ausgabe Java Basics - Anfänger-Themen 4
H Frage zu arithmetischen Operationen Java Basics - Anfänger-Themen 20
F Kurze Frage zu replace() Java Basics - Anfänger-Themen 19
JavaSchmecktLecker Polymorphie Frage zur Methodenüberschreibung Java Basics - Anfänger-Themen 21
J Frage zu einem "Taschenrechner" code Java Basics - Anfänger-Themen 9
B Erste Schritte Frage zu Instanzierung und Referenzen Java Basics - Anfänger-Themen 8
DoubleM Runtime.getRuntime().exec Frage Java Basics - Anfänger-Themen 2
J Eine theoretische Frage zur Praxis - JPanel oder Canvas Java Basics - Anfänger-Themen 5
O Frage: Formaler Typbezeichner? Java Basics - Anfänger-Themen 3
I BlueJ Queue Frage für Klausur Java Basics - Anfänger-Themen 2
N Verständnis Frage zu Variablen Java Basics - Anfänger-Themen 3
N Spezielle frage zum Comparator Java Basics - Anfänger-Themen 6
L Frage zum Array Java Basics - Anfänger-Themen 1
A Frage zum UML Design Java Basics - Anfänger-Themen 1
I Hilfe bei Klausur Frage Java Basics - Anfänger-Themen 8
izoards Drucken Frage zu FAQ Beitrag Java Basics - Anfänger-Themen 2
J Frage zu meinem Code (OOP) Java Basics - Anfänger-Themen 4
sserio Split() -> Regex Frage. Java Basics - Anfänger-Themen 7
A OCA Study Guide: 2. Frage aus Kapitel 3 Java Basics - Anfänger-Themen 9
sserio Date Library Frage Java Basics - Anfänger-Themen 9
Max246Sch Frage zu Währungsrechner Code Java Basics - Anfänger-Themen 2
sserio Frage zu HashMaps Java Basics - Anfänger-Themen 20
sserio Frage zu Threading - Multithreading Java Basics - Anfänger-Themen 2
sserio Frage zu Lambda Ausdrücken Java Basics - Anfänger-Themen 7
sserio Frage zu BigInteger Java Basics - Anfänger-Themen 1
D Frage bzgl. Enum-Handhabung Java Basics - Anfänger-Themen 16
xxx12 Frage Java Basics - Anfänger-Themen 2
I Generelle Frage zu Mikroservices (Spring Boot?), Docker... Java Basics - Anfänger-Themen 7
R Frage zu Methoden (Rückgabewert u. ohne.) Java Basics - Anfänger-Themen 2
A Frage zur programmierung Java Basics - Anfänger-Themen 12
M Frage zur Methode split der Klasse String Java Basics - Anfänger-Themen 32
R Input/Output Frage zu Java IO Java Basics - Anfänger-Themen 6
M Frage zu printWriter Java Basics - Anfänger-Themen 5
C Frage zu OLSMultipleLinearRegression Java Basics - Anfänger-Themen 31
KogoroMori21 Frage zum Euklidischen Algorithmus Java Basics - Anfänger-Themen 11
S Verständnis-Frage zu einer HÜ? Java Basics - Anfänger-Themen 1
F Frage betreff Programm mit dem man C++-Code in JAVA-Code übersetzen lassen kann Java Basics - Anfänger-Themen 2
L Frage zur Ticket Maschine Java Basics - Anfänger-Themen 1
J Frage zu OOP-Klassendiagramm Java Basics - Anfänger-Themen 8
OSchriever Frage zu Compiler Java Basics - Anfänger-Themen 8
H Frage zu Throw Exception Java Basics - Anfänger-Themen 2
TimoN11 Frage zu Java-Vererbung (Cast) Java Basics - Anfänger-Themen 5
Bademeister007 Hallo Leute ich hab eine Frage zur ArrayList Java Basics - Anfänger-Themen 8
F Frage betreff Programmierbücher zu Lagerverwaltung als Konsolenprogramm Java Basics - Anfänger-Themen 3
dieter000 Kurze Frage kann mir ejmand kurz diesen Code erklären, bzw wie man die zeilen erklärt und so Java Basics - Anfänger-Themen 1
I String.split regex Frage Java Basics - Anfänger-Themen 2
N Best Practice Frage zum MVC-Pattern Java Basics - Anfänger-Themen 2
dieter000 Frage zu einem Beispiel... Java Basics - Anfänger-Themen 5
J Frage zum Loggen Java Basics - Anfänger-Themen 18
J Methoden Frage: Array-Werte in anderer Methode ändern Java Basics - Anfänger-Themen 4
Zrebna Frage zum "Referenzen-konzept" in Java Java Basics - Anfänger-Themen 8
JD_1998 Array-Position aus einer Methode in einer anderen ausgeben (Kurze Frage) Java Basics - Anfänger-Themen 2
marcooooo Frage zu bestimmten Beispiel Java Basics - Anfänger-Themen 31
NeoLexx equals()-Methode Verständnis Frage anhand Code Beispiel Java Basics - Anfänger-Themen 22
N Input/Output Eine Frage über system.out.println. Java Basics - Anfänger-Themen 10
B Erste Schritte Learning Coding (!) Frage an erfahrene Programmierer. Java Basics - Anfänger-Themen 23
M konzeptuelle Frage: In welcher Klasse definiert man am Besten Methoden, die die Kommunikation mit dem User regeln? Java Basics - Anfänger-Themen 8
B Frage zum Code verständnis im Resultat Java Basics - Anfänger-Themen 10
C Exception-Frage Java Basics - Anfänger-Themen 3
J Eine Frage zur Schreibweise == ? : Java Basics - Anfänger-Themen 3
S Frage des Designs Java Basics - Anfänger-Themen 1
JavaTalksToMe Extends/Implements Frage Java Basics - Anfänger-Themen 3
pkm Frage zu Servletfunktion Java Basics - Anfänger-Themen 0
B Frage zur Währungsumrechnung Java Basics - Anfänger-Themen 3
S Allgemeine Frage über Generics und Vererbungen Java Basics - Anfänger-Themen 5
Kirby.exe Frage zur Verwendung von Interfaces Java Basics - Anfänger-Themen 6
D Frage zu Strings einer Exception Java Basics - Anfänger-Themen 4
L Wie frage ich ab, ob in einem Array, Werte doppelt vorkommen? Java Basics - Anfänger-Themen 4
D Frage zur IDE IntelliJ IDEA Java Basics - Anfänger-Themen 6
H Frage zum 2d Array Java Basics - Anfänger-Themen 1
N Frage zum Newton-Fraktal Java Basics - Anfänger-Themen 1
H Frage zu interfaces Java Basics - Anfänger-Themen 1
J Frage dazu Variablen klassenübergreifend zu verändern Java Basics - Anfänger-Themen 22
I Frage zu SkipList Java Basics - Anfänger-Themen 4
G Frage zu JScrollPane Java Basics - Anfänger-Themen 12
Kirby.exe Allgemeine Frage Java Basics - Anfänger-Themen 3
W Frage zu anonymen Klassen Java Basics - Anfänger-Themen 4
J Kleine Frage zu OOP Java Basics - Anfänger-Themen 371
S Frage Klasse und Objekte Java Basics - Anfänger-Themen 2
F Frage zu Iteratoren Java Basics - Anfänger-Themen 2
C Erste Schritte Frage zur ArrayList Java Basics - Anfänger-Themen 15
J Frage zur Vererbung Java Basics - Anfänger-Themen 1
H Frage zur ermittlung eines doppelte Paars aus Sotieralgorithmus Java Basics - Anfänger-Themen 4
H Frage zum Array Java Basics - Anfänger-Themen 17
G Schach -Frage 2- Maussteuerung Java Basics - Anfänger-Themen 7
G Schach in Java - Allgemeine Frage zur Architektur Java Basics - Anfänger-Themen 7
B Fachliche Frage bei Rechnungen Java Basics - Anfänger-Themen 16
B Frage zu: String... strings -> Ungleiche Anzahl an Parameter? Java Basics - Anfänger-Themen 4
B Frage zu Datenbank Design - Rechnungen, Angebote... und deren Positionen Java Basics - Anfänger-Themen 4
H Frage zu Parameter einer Methode Java Basics - Anfänger-Themen 2
H Einfache Frage zur Punktnotation objektname.methode(wert) Java Basics - Anfänger-Themen 2
H Frage zu Parameter einer Methode Java Basics - Anfänger-Themen 3
H Frage zur if-Bedingung bzw switch case Java Basics - Anfänger-Themen 6

Ähnliche Java Themen

Neue Themen


Oben