カテゴリー: Computer

  • より高度なCSRF対策 – URL/URI個別にバリデーションする方法

    ハッシュ関数は色々な場面で利用できます。このエントリではハッシュ関数の使い方、特にリクエストにサインする方法として、データベースを使わずURI個別のCSRFトークンを生成しバリデーションする方法を紹介します。

    (さらに…)

  • PHPのmt_rand()/rand()問題

    PHPのmt_rand()とrand()には状態の初期化/再初期化に問題があります。話しを簡単にするためにrand()をmt_rand()のエイリアスにする提案

    https://wiki.php.net/rfc/rng_fixes

    が適用された状態を前提にMT rand問題として解説します。しかし、基本的には古いPHPでrand()を使う場合も同じ(かそれ以上)の問題があります。

    そもそもMT randは暗号理論的に安全な乱数生成器ではありません。安全な乱数の取得に使ってはなりませんが、MT rand以前の乱数に比べ予測が困難、ということで不適切な箇所で利用しているケースが散見されます。

    結論から言うと、MT randで生成された乱数値は安全ではなく非常に危険1、です。

    (さらに…)

  • Uncaught Error: Call to undefined function get_user_attribute()

    Uncaught Error: Call to undefined function get_user_attribute()

    で困っている方向けの情報です。以下の様なエラーでWordpressのJetPackの管理ページなどが使えなくなります。

    [Mon Dec 05 10:05:51.204342 2016] [php7:error] [pid 1928] [client XX.XX.XX.XX:58566] PHP Fatal error:  Uncaught Error: Call to undefined function get_user_attribute() in /path/to/wp/wp-content/plugins/jetpack/modules/after-the-deadline.php:34

    (さらに…)

  • ISO 27000の入力データ妥当性確認

    セキュリティ標準では入力データの妥当性確認(入力バリデーション)が要求されています。具体的な方法はBS 7799(英国のJIS規格のような物、2000年に国際標準化)が作られた時(90年代後半)から記載されており、前の版までのISO 270001にも記載されています。2013年版のISO 27000ではセキュアプログラミングが普及したので具体的な方法などは省略しています。(日本では普及していないような。。)

    セキュアプログラミングの基本中の基本がセキュリティ対策ではない、というような意味が全く解らない議論もあるのが現状です。

    かなり昔に似たようなことを書いたようにも思いますが、記憶が定かではありません。今でも有効なので改めて(?)ブログにします。

    (さらに…)

  • ホワイトリストの作り方

    ホワイトリストの考え方/作り方は難しくありません。しかし、間違えていることが少なくないようです。

    GoogleがCSP(Content Security Policy – ホワイトリスト型のJavaScriptインジェクション対策)の利用状況を調べたところ以下のような結果が得られました。

    we take a closer look at the practical benefits of adopting CSP and identify significant flaws in real-world deployments that result in bypasses in 94.72% of all distinct policies.

    なんと、約95%のCSP利用サイトがCSPの保護が無効になるような設定になっていた、としています。

    (さらに…)

  • セッションデータインジェクション

    PHP 5.6.25/7.010以降で修正されたセッションデータインジェクション

    • Fixed bug #72681 (PHP Session Data Injection Vulnerability). (CVE-2016-7125)

    の解説です。

    この脆弱性を利用するとオブジェクトインジェクションが簡単に行えます。結構深刻な問題ですが、あまり話題にはなっていないように思います。

    (さらに…)

  • プライベートサイトを作るならPHPのURL Rewriterを使う

    クロスサイト・リクエスト(他のWebサイトから自分のサイトへURLリンクやPOSTでアクセスする)を制限したいWebアプリケーションは結構あります。例えば、ホームルーターの管理ページを作る場合、クロスサイト・リクエストは有用などころか有害です。ホームルーターの管理ページにはクロスサイト・リクエストによる脆弱性が多数報告されています。

    PHPの基本機能を使えば、クロスサイト・リクエストを簡単かつ丸ごと拒否することができます。CSRFやXSS1を完全かつ簡単に拒否する仕組みを作れます。

    (さらに…)

  • 完全なSQLインジェクション対策

    不完全なSQLインジェクション対策だけで、SQLインジェクション対策は万全、と誤解しているケースが少なくないです。

    • プリペアードクエリ/プレイスホルダを使ったSQLインジェクション対策でOK

    は誤りです。「とにかくプレイスホルダを使おう」では脆弱性は無くなりません。

    簡単な証明:プリペアードクエリ”だけ”では、識別子(カラム/テーブル等)を使うソートクエリ、特定カラム抽出クエリを”原理的”に無害化できない。識別子のエスケープ/バリデーションが必須。(問題はコレだけはありません)

    似たような間違いに「出力対策をするのがセキュリティ対策」だとする考え方があります。こういう考え方になる原因はセキュリティ設計や原則を理解していないことにあると思われます。

    https://blog.ohgaki.net/output-only-security-is-anti-practice

    アンチプラクティスであっても正しく動作するならまだ良い方です。しかし、論理的・原理的に出力対策”だけ”では正しく動作するアプリケーションは作れません

    参考:

    (さらに…)

  • ソーシャルメディアフィンガープリントとその対策

    ソーシャルメディアフィンガープリントがまた話題になっているようです。ソーシャルメディアフィンガープリントとは何か?およびその対策です。

    ソーシャルメディアに限らず、ログインをサポートしているサイトであれば、全て対象です。

    (さらに…)

  • PHPスクリプトの分析ツール

    PHPスクリプトを分析するツールをまとめたページの紹介です。

    (さらに…)

  • 根本的なセキュリティ対策とは何か?

    セキュリティ対策において対策が「根本的」な対策であるかどうか?はあまり重要ではないです。セキュリティ対策において重要なのは対策が「効果的」であるかどうか、が重要だからです。

    この基本を押さえた上で、ソフトウェアの「根本的な対策」とは何かを考えてみます。

    (さらに…)

  • PHPのheader関数とheaders_remove関数の注意点

    PHPのheader関数とheader_remove関数の注意点です。あまり使わないと思いますが、Set-Cookieヘッダーや他のヘッダーで注意しないと問題になります。普段はsetcookie関数でクッキーを設定していてたまたまheader関数でクッキーを設定した、という場合にheader関数とsetcookie関数の仕様の違いにより、思ってもいない結果になります。

    (さらに…)

  • WordPressをできるだけ安全に使うプラグイン

    このブログで利用しているセキュリティ関係のプラグインを紹介します。こういう情報はあまり公開しない方が良いのですが、本気の攻撃者の場合はプラグインファイルの存在を総当たりで検出すれば判ってしまいます。

    (さらに…)

  • ソフトウェア開発環境のセキュリティ対策

    ソフトウェアの開発環境は通常の環境と違う対策が必要です。その理由は開発環境には

    • 他人が書いた未検証のモノ
    • 自分が書いた実験用のモノ
    • 他人または自分が書いた作りかけのモノ
    • 制御された環境での利用を前提としたモノ
    • 意図的に利用している新しいモノ(リリース前のソフトウェアなど)
    • 意図的に利用している古いモノ(古いシステムサポートためなど)

    ※モノにはコード/ライブラリ/ツール/アプリ/システム などがあります。

    などがある為です。開発環境はその他の環境に比べ「とにかく危険なモノがいっぱい」です。

    更に最近ではソーシャルコーディングが当たり前になり、他人が書いた未検証のコードがどんどん実行される状態も当たり前です。それも1つ2つのライブラリではなく、依存性から何百、場合によっては何千というライブラリなどが自動的にダウンロードされ実行されています。

    これがどういう状況かというと「PCがやっと使えるくらいのユーザーが、インターネットからプログラムをダウンロードしまくって実行している状況」とあまり変わりません。

    参考: SOHO・家庭の安全なネットワーク環境2018

    (さらに…)

  • WordPress + HTTPS + リバースプロキシ = このページにアクセスする権限がありません。

    リバースプロキシ環境で結構ハマったのでブログにします。結論から書くと、WordPressのドキュメント

    Note: FORCE_SSL_ADMIN should be set before wp-settings.php is required.

    wp-settings.phpを読み込む前にFORCE_SSL_ADMINは定義しなければならない、と書いてありますがSSL関係の設定は全てこれの前に書かないと動作しません。

    (さらに…)