【活用ガイド】

JVNDB-2026-005831

z-libsのZen CにおけるOS コマンドインジェクションの脆弱性

概要

Zen Cは、人間が読みやすいGNU C/C11にコンパイルされるシステムプログラミング言語です。バージョン0.4.2以前のZen Cコンパイラにはコマンドインジェクションの脆弱性(CWE-78)が存在しており、ローカルの攻撃者が`-o`コマンドライン引数を介して特別に細工された出力ファイル名を提供することで任意のシェルコマンドを実行できる可能性がありました。この脆弱性は`main`アプリケーションロジック(具体的には`src/main.c`)に存在し、コンパイラがバックエンドCコンパイラを呼び出すためのシェルコマンド文字列を構築する際に発生していました。このコマンド文字列はユーザーが制御する出力ファイル名などのさまざまな引数を連結して作成され、その後`system()`関数を使って実行されていました。`system()`はコマンドを解析して実行するためのシェルを呼び出すため、出力ファイル名内のシェルメタ文字がシェルによって解釈され、任意のコマンドが実行可能となっていました。ビルドスクリプトやCI/CDパイプラインの設定などを通じて`zc`コンパイラに渡されるコマンドライン引数に影響を与えられる攻撃者は、コンパイラを実行しているユーザーの権限で任意のコマンドを実行できます。この脆弱性は、`system()`呼び出しを排除し、`ArgList`の実装および内部引数処理を導入することでバージョン0.4.2で修正されました。ユーザーはZen Cバージョン0.4.2以降にアップデートすることを推奨されます。
CVSS による深刻度 (CVSS とは?)

CVSS v3 による深刻度
基本値: 7.3 (重要) [NVD値]
  • 攻撃元区分: ローカル
  • 攻撃条件の複雑さ: 低
  • 攻撃に必要な特権レベル: 低
  • 利用者の関与: 要
  • 影響の想定範囲: 変更なし
  • 機密性への影響(C): 高
  • 完全性への影響(I): 高
  • 可用性への影響(A): 高
影響を受けるシステム


z-libs
  • Zen C 0.4.2 未満

本脆弱性の影響を受ける製品の詳細については、ベンダ情報および参考情報をご確認ください。
想定される影響

当該ソフトウェアが扱う全ての情報が外部に漏れる可能性があります。
また、当該ソフトウェアが扱う全ての情報が書き換えられる可能性があります。
さらに、当該ソフトウェアが完全に停止する可能性があります。
そして、この脆弱性を悪用した攻撃の影響は、他のソフトウェアには及びません。
対策

正式な対策が公開されています。ベンダ情報を参照して適切な対策を実施してください。
ベンダ情報

GitHub
CWEによる脆弱性タイプ一覧  CWEとは?

  1. OSコマンドインジェクション(CWE-78) [その他]
共通脆弱性識別子(CVE)  CVEとは?

  1. CVE-2026-28207
参考情報

  1. National Vulnerability Database (NVD) : CVE-2026-28207
更新履歴

  • [2026年03月04日]
      掲載