BT

Node.jsのセキュリティ向上を目指すNode Security Project

| 作者: Sergio De Simone フォローする 12 人のフォロワー , 翻訳者 吉田 英人 フォローする 0 人のフォロワー 投稿日 2014年7月13日. 推定読書時間: 2 分 |

原文(投稿日:2014/06/25)へのリンク

Node Security Projectはこの数ヶ月間,Node.jsのセキュリティ向上に対して静かに取り組んでいる。Node.jsの既存モジュールベースの監査を通じて"Nodeの全般的状況を改善すると同時に,開発者と企業に対して,Node.jsの世界のセキュリティ状態に関する信頼性を提供する"ことがその目標だ。

今回の監査作業は,チケットシステムを通じて分散的な方法で実施される計画である。アドバイザリやイシュー管理,プルリクエストを行うバックボーンを提供することによって,Nodeコミュニティの支援を得ながらモジュール修正を行う考えだ。

Node.jsに関するセキュリティ上の大きな懸念のひとつは,サーバサイドJavaScriptインジェクション(SSJSインジェクション)の可能性に関するものです。これはクロスサイトJavaScriptインジェクションにも似ています。Adobeの研究員であるBryan Sullivan, Senior Security両氏が,SSJSインジェクションによって可能になる攻撃と,アプリないしデータが被るリスクを説明した資料を公開しています

注意すべきなのは,サーバサイドJavaScriptインジェクション脆弱性の利用が,クロスサイトスクリプティングよりもSQLインジェクションの方に近いことだ。折り返し型(refrected)XSSやDOMベースのXSSのように,中間犠牲者となるユーザに対してソーシャルエンジニアリングを仕掛ける必要はない。SSJSインジェクションでは,攻撃者は意図的に作成したHTTP要求を使って,直接アプリケーションを攻撃することができる。

セキュリティマニアを自称するブロガの\0/ bish \0/氏が書いているように,Node.jsには,開発者が特に注意を払うべき要素の組み合わせが存在している。ひとつは"いとも簡単にサーバサイドインジェクションに利用されてしまう"evalの存在であり,もうひとつは"イベント駆動の単一スレッドプログラムモデル"であるが故に,"単純なエラーもでサービス拒否状態が作り出せてしまう"ことだ。さらに加えて,“安全のためには,暗黙のグローバル(implied globals)や"with”, “eval” のようなアンチパターンも避けるべきです”と氏は言う。氏はさらに,自身のブログ記事の中で,エクスプロイトにつながる可能性のある,これらの言語機能の誤った使い方をいくつか紹介している。

このように,Node.jsが他に比べて際立ってセキュリティの低いテクノロジなのではない。上に述べたような危険性は,どのサーバサイド言語にも広く存在している。Adam Baldwin氏がModulusのインタビューで語っているように,Nodeプラットフォームに影響するセキュリティ上の懸念に対する,開発者の意識の向上が問題なのだ。

Node Security Projectは,Nodeコミュニティにおけるセキュリティのアプローチ方法を変えるための活動です。セキュリティ思想の啓蒙を目指した努力と,コミュニティによって開発されたモジュールの監査を行って,その結果を公表します。

この記事に星をつける

おすすめ度
スタイル

こんにちは

コメントするには InfoQアカウントの登録 または が必要です。InfoQ に登録するとさまざまなことができます。

アカウント登録をしてInfoQをお楽しみください。

あなたの意見をお聞かせください。

HTML: a,b,br,blockquote,i,li,pre,u,ul,p

このスレッドのメッセージについてEmailでリプライする
コミュニティコメント

HTML: a,b,br,blockquote,i,li,pre,u,ul,p

このスレッドのメッセージについてEmailでリプライする

HTML: a,b,br,blockquote,i,li,pre,u,ul,p

このスレッドのメッセージについてEmailでリプライする

ディスカッション

InfoQにログインし新機能を利用する


パスワードを忘れた方はこちらへ

Follow

お気に入りのトピックや著者をフォローする

業界やサイト内で一番重要な見出しを閲覧する

Like

より多いシグナル、より少ないノイズ

お気に入りのトピックと著者を選択して自分のフィードを作る

Notifications

最新情報をすぐ手に入れるようにしよう

通知設定をして、お気に入りコンテンツを見逃さないようにしよう!

BT