diff options
author | Tatu Lund <tatu@vaadin.com> | 2021-02-01 17:51:22 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-02-01 17:51:22 +0200 |
commit | 7cb91b3b9995c92bfd2bfb694669f02d7fa44618 (patch) | |
tree | 6fa40e1a5728a95947a2ab59e45124102f97104d /server/src | |
parent | 885c2298fd709f4b05ee9fd4b38286c82c37cd1e (diff) | |
download | vaadin-framework-7cb91b3b9995c92bfd2bfb694669f02d7fa44618.tar.gz vaadin-framework-7cb91b3b9995c92bfd2bfb694669f02d7fa44618.zip |
fix: use time-constant comparison for CSRF tokens (#12188)
This hardens the framework against a theoretical timing attack based on
comparing how quickly a request with an invalid CSRF token is rejected.
Cherry-picked from: https://github.com/vaadin/flow/pull/9875
Diffstat (limited to 'server/src')
-rw-r--r-- | server/src/main/java/com/vaadin/server/VaadinService.java | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/server/src/main/java/com/vaadin/server/VaadinService.java b/server/src/main/java/com/vaadin/server/VaadinService.java index 31ddf7b8ba..45e71dace7 100644 --- a/server/src/main/java/com/vaadin/server/VaadinService.java +++ b/server/src/main/java/com/vaadin/server/VaadinService.java @@ -29,6 +29,8 @@ import java.io.Serializable; import java.lang.reflect.Constructor; import java.net.MalformedURLException; import java.net.URL; +import java.nio.charset.StandardCharsets; +import java.security.MessageDigest; import java.util.ArrayList; import java.util.Collections; import java.util.HashMap; @@ -1962,7 +1964,9 @@ public abstract class VaadinService implements Serializable { .isXsrfProtectionEnabled()) { String sessionToken = session.getCsrfToken(); - if (sessionToken == null || !sessionToken.equals(requestToken)) { + if (sessionToken == null || !MessageDigest.isEqual( + sessionToken.getBytes(StandardCharsets.UTF_8), + requestToken.getBytes(StandardCharsets.UTF_8))) { return false; } } |