← 戻る
CVE-2026-42349
@clerk/shared の脆弱性 (CVE-2026-42349)
概要
@clerk/shared に 脆弱性 (CVE-2026-42349) が存在。不正な操作・情報露出のリスクがあります。``clerkMiddleware`` 経由で攻撃可能。対策: `4.8.3` 以上に更新。
AI要約 snake-internal / snake-material-v2
@clerk/shared という製品で、CVE-2026-42349 という番号がついた弱点 (脆弱性) が見つかりました。
悪い人がインターネット越しに ``clerkMiddleware`` のような特定の入り口を狙うことで、製品の中を不正に操作できてしまいます。
不正な操作・情報露出のリスクがあります。重要度は CVSS スコア ?/10 です。
対策: @clerk/shared を **4.8.3** 以上に更新してください。
心配なら、システム担当者や製品の公式サイトで「@clerk/shared CVE-2026-42349」を検索してください。
CVE-2026-42349 (@clerk/shared) — CWE-754 /
脆弱箇所: `clerkMiddleware` / `reverification` / `role` / `permission`
修正バージョン: `4.8.3` (即時適用推奨)
対応方針: 1) SBOMで影響バージョン横断確認, 2) ステージング検証→本番更新, 3) WAF/プロキシで該当エンドポイントを監視, 4) ログでIOC調査。
参考: 当ページの『参照URL』の GHSA / vendor advisory / patched release を参照。
❓ 何が問題か
@clerk/shared に **脆弱性** (CWE-754) があります。攻撃者は ``clerkMiddleware`` を経由して脆弱な処理に到達し、認証なしで悪用できます。
📍 影響範囲
@clerk/shared のうち 。攻撃箇所: `clerkMiddleware` / `reverification` / `role` / `permission`。
🔥 重要度
重要度: ?。不正な操作・情報露出のリスクがあります
🔧 修正方法
**4.8.3** に更新してください。
🛡️ 暫定回避
修正版が未提供時は、影響機能の無効化・WAFルール・ネットワークACLでの遮断を検討。
🔍 検知方法
Webサーバ・プロキシ・WAFログで該当CVEのIOCに合致する不審リクエストを検索。SBOM/依存ファイルで影響バージョンを横断確認。
対応アクション (7段階)
SOC/SREチームが順番に実行すべき具体的なステップとコマンド例
-
1影響範囲の特定 identify
grep -r '@clerk/shared' . | grep -v node_modulesリポジトリと本番環境の依存ファイル (package-lock.json / requirements.txt / go.sum / Gemfile.lock 等) で `@clerk/shared` を grep し、稼働しているサービス・バージョンを把握する。
-
6パッチ適用 patch
Upgrade @clerk/shared to 4.8.3ステージング環境で 4.8.3 に上げて回帰テスト → 本番反映。回帰テストはアプリの主要ハッピーパスと、Step 3 で見つけた異常検知の続報チェックを含めること。
-
7事後検証 verify
Confirm patched version is live in productionパッチ適用後、ステージングで PoC または同等の悪用パターンを再現して脆弱性が閉じたことを確認。本番では Step 3 と同じログクエリでアラート再発が無いか継続監視。
影響パッケージ
npm
@clerk/shared
[{"type":"SEMVER","events":[{"introduced":"4.0.0"},{"fixed":"4.8.3"}]}]
npm
@clerk/backend
[{"type":"SEMVER","events":[{"introduced":"3.0.0"},{"fixed":"3.2.14"}]}]
npm
@clerk/nextjs
[{"type":"SEMVER","events":[{"introduced":"7.0.0"},{"fixed":"7.2.4"}]}]
npm
@clerk/clerk-js
[{"type":"SEMVER","events":[{"introduced":"6.0.0"},{"fixed":"6.7.5"}]}]
npm
@clerk/clerk-react
[{"type":"SEMVER","events":[{"introduced":"5.9.0"},{"fixed":"5.61.6"}]}]
npm
@clerk/react
[{"type":"SEMVER","events":[{"introduced":"6.0.0"},{"fixed":"6.4.3"}]}]
npm
@clerk/vue
[{"type":"SEMVER","events":[{"introduced":"2.0.0"},{"fixed":"2.0.16"}]}]
npm
@clerk/astro
[{"type":"SEMVER","events":[{"introduced":"3.0.0"},{"fixed":"3.0.18"}]}]
npm
@clerk/nuxt
[{"type":"SEMVER","events":[{"introduced":"2.0.0"},{"fixed":"2.2.5"}]}]
npm
@clerk/clerk-expo
[{"type":"SEMVER","events":[{"introduced":"2.2.11"},{"fixed":"2.19.36"}]}]
npm
@clerk/expo
[{"type":"SEMVER","events":[{"introduced":"3.0.0"},{"fixed":"3.2.2"}]}]
npm
@clerk/react-router
[{"type":"SEMVER","events":[{"introduced":"3.0.0"},{"fixed":"3.1.4"}]}]
npm
@clerk/tanstack-react-start
[{"type":"SEMVER","events":[{"introduced":"1.0.0"},{"fixed":"1.1.4"}]}]
npm
@clerk/chrome-extension
[{"type":"SEMVER","events":[{"introduced":"3.0.0"},{"fixed":"3.1.15"}]}]
npm
@clerk/fastify
[{"type":"SEMVER","events":[{"introduced":"3.0.0"},{"fixed":"3.1.16"}]}]
npm
@clerk/express
[{"type":"SEMVER","events":[{"introduced":"2.0.0"},{"fixed":"2.1.6"}]}]
npm
@clerk/hono
[{"type":"SEMVER","events":[{"introduced":"0.0.2"},{"fixed":"0.1.16"}]}]