Логотип exploitDog
Консоль
Логотип exploitDog

exploitDog

github логотип

GHSA-cmp6-m4wj-q63q

Опубликовано: 05 дек. 2025
Источник: github
Github: Прошло ревью
CVSS4: 8.2

Описание

yawkat LZ4 Java has a possible information leak in Java safe decompressor

Summary

Insufficient clearing of the output buffer in Java-based decompressor implementations in lz4-java 1.10.0 and earlier allows remote attackers to read previous buffer contents via crafted compressed input. In applications where the output buffer is reused without being cleared, this may lead to disclosure of sensitive data.

JNI-based implementations are not affected.

Details

During the decompression process, the lz4 algorithm may have to repeat data that was previously decompressed in the same input frame. In the Java implementation, this is implemented by copy operations within the output buffer.

With a crafted input, an attacker may induce the Java implementation to copy from a region in the output buffer that does not contain decompressed data yet. If that region contains sensitive information because the output buffer was not cleared prior to decompression, that data will then be copied to the decompressed output.

  • LZ4Factory.nativeInstance().safeDecompressor() is not affected.
  • LZ4Factory.nativeInstance().fastDecompressor() is affected because it actually uses safeInstance() since 1.8.1. In 1.8.0 and earlier versions, this implementation is instead vulnerable to the more severe CVE‐2025‐12183, so downgrading is not a solution.
  • Both decompressors of LZ4Factory.safeInstance(), LZ4Factory.unsafeInstance() and LZ4Factory.fastestJavaInstance() are affected.
  • LZ4Factory.fastestInstance() uses the nativeInstance or fastestJavaInstance depending on platform. LZ4Factory.fastestInstance().fastDecompressor() is always affected, while LZ4Factory.fastestInstance().safeDecompressor() is affected only when JNI cannot be used (e.g. on unsupported platforms).

Independent of this vulnerability, it is recommended that users migrate from fastDecompressor to safeDecompressor, as the latter is more performant (despite the name).

The impact of this vulnerability depends on how user code interacts with the decompression API. Users that allocate a new destination buffer each time, or use only zeroed buffers, are not impacted. When the buffer is reused, however, the confidentiality impact can be severe. This vulnerability is marked as VC:H out of caution.

Mitigation

lz4-java 1.10.1 fixes this issue without requiring changes in user code.

If you cannot upgrade to 1.10.1, you can mitigate this vulnerability by zeroing the output buffer before passing it to the decompression function.

Relation to CVE‐2025‐12183

This CVE is a different attack than CVE‐2025‐12183, affecting different implementations with different impact. This new vulnerability was discovered by CodeIntelligence during research that followed up on CVE‐2025‐12183. Users are recommended to upgrade to 1.10.1 to fix both vulnerabilities.

Пакеты

Наименование

at.yawk.lz4:lz4-java

maven
Затронутые версииВерсия исправления

<= 1.10.0

1.10.1

Наименование

org.lz4:lz4-java

maven
Затронутые версииВерсия исправления

<= 1.8.1

Отсутствует

Наименование

org.lz4:lz4-pure-java

maven
Затронутые версииВерсия исправления

<= 1.8.1

Отсутствует

Наименование

net.jpountz.lz4:lz4

maven
Затронутые версииВерсия исправления

<= 1.8.1

Отсутствует

EPSS

Процентиль: 44%
0.00211
Низкий

8.2 High

CVSS4

Дефекты

CWE-201

Связанные уязвимости

ubuntu
2 месяца назад

yawkat LZ4 Java provides LZ4 compression for Java. Insufficient clearing of the output buffer in Java-based decompressor implementations in lz4-java 1.10.0 and earlier allows remote attackers to read previous buffer contents via crafted compressed input. In applications where the output buffer is reused without being cleared, this may lead to disclosure of sensitive data. JNI-based implementations are not affected. This vulnerability is fixed in 1.10.1.

nvd
2 месяца назад

yawkat LZ4 Java provides LZ4 compression for Java. Insufficient clearing of the output buffer in Java-based decompressor implementations in lz4-java 1.10.0 and earlier allows remote attackers to read previous buffer contents via crafted compressed input. In applications where the output buffer is reused without being cleared, this may lead to disclosure of sensitive data. JNI-based implementations are not affected. This vulnerability is fixed in 1.10.1.

debian
2 месяца назад

yawkat LZ4 Java provides LZ4 compression for Java. Insufficient cleari ...

oracle-oval
19 дней назад

ELSA-2026-0752: jmc security update (IMPORTANT)

EPSS

Процентиль: 44%
0.00211
Низкий

8.2 High

CVSS4

Дефекты

CWE-201