CVE-2026-31962

HIGH CVSS 4.0: 8,8 EPSS 0.06%
Обновлено 19 марта 2026
Htslib
Параметр Значение
CVSS 8,8 (HIGH)
Уязвимые версии 1.22 — 1.22.2
Устранено в версии 1.21.1
Тип уязвимости CWE-122 (Переполнение буфера в куче), CWE-125 (Чтение за пределами буфера), CWE-129 (Некорректная проверка индекса массива), CWE-787 (Запись за пределами буфера)
Поставщик Htslib
Публичный эксплойт Нет

HTSlib — это библиотека для чтения и записи форматов файлов биоинформатики. CRAM — это сжатый формат, в котором хранятся данные выравнивания последовательностей ДНК. Хотя большинство записей о выравнивании хранят значения последовательности ДНК и качества, формат также позволяет в некоторых случаях опускать эти данные для экономии места. Из-за некоторых особенностей формата CRAM необходимо осторожно обращаться с этими записями, поскольку на самом деле они будут хранить данные, которые необходимо использовать, а затем удалять.

Unfortunately the `cram_decode_seq()` did not handle this correctly in some cases. Если это произошло, это могло привести к чтению одного байта из-за конца выделения кучи с последующей записью одного байта, контролируемого злоумышленником, в то же место. Использование этой ошибки приводит к переполнению буфера кучи.

Если пользователь откроет файл, созданный для использования этой проблемы, это может привести к сбою программы или перезаписи данных и структур кучи способами, не ожидаемыми программой. Возможно, это можно будет использовать для выполнения произвольного кода. Версии 1.23.1, 1.22.2 и 1.21.1 включают исправления этой проблемы.

Для этой проблемы не существует решения.

Показать оригинальное описание (EN)

HTSlib is a library for reading and writing bioinformatics file formats. CRAM is a compressed format which stores DNA sequence alignment data. While most alignment records store DNA sequence and quality values, the format also allows them to omit this data in certain cases to save space. Due to some quirks of the CRAM format, it is necessary to handle these records carefully as they will actually store data that needs to be consumed and then discarded. Unfortunately the `cram_decode_seq()` did not handle this correctly in some cases. Where this happened it could result in reading a single byte from beyond the end of a heap allocation, followed by writing a single attacker-controlled byte to the same location. Exploiting this bug causes a heap buffer overflow. If a user opens a file crafted to exploit this issue, it could lead to the program crashing, or overwriting of data and heap structures in ways not expected by the program. It may be possible to use this to obtain arbitrary code execution. Versions 1.23.1, 1.22.2 and 1.21.1 include fixes for this issue. There is no workaround for this issue.

Характеристики атаки

Способ атаки
По сети
Атака возможна удалённо
Сложность
Низкая
Легко эксплуатировать
Условия для атаки
Не требуются
Нет дополнительных условий
Нужны права
Не требуются
Права не нужны
Участие пользователя
Не требуется
Не нужно действие пользователя

Последствия

Конфиденциальность
Низкое
Частичная утечка данных
Целостность
Высокое
Полная модификация данных
Доступность
Низкое
Частичное нарушение работы

Строка CVSS v4.0

Уязвимые продукты 3

Конфигурация От (включительно) До (исключительно)
Htslib Htslib
cpe:2.3:a:htslib:htslib:*:*:*:*:*:*:*:*
1.21.1
Htslib Htslib
cpe:2.3:a:htslib:htslib:*:*:*:*:*:*:*:*
1.22 1.22.2
Htslib Htslib
cpe:2.3:a:htslib:htslib:1.23:*:*:*:*:*:*:*