ECサイト

クロスサイトスクリプティングとSQLインジェクションってなに?

Webサイトを閲覧するだけで個人情報が盗まれたり、さまざまな被害を引き起こすセキュリティ問題。
クロスサイトスクリプティング(XSS)とSQLインジェクションの違いについて解説していきます。是非最後までご覧ください!

クロスサイトスクリプティング(XSS)とは?


クロスサイトスクリプティング(XSS)とは、Webアプリケーションの脆弱性を利用して行われるサイバー攻撃の1つです。
IPA(情報処理推進機構)が公開した資料によると、2020年7月~9月に届出された脆弱性のうち、約58%がこのクロスサイトスクリプティングであるとされており、近年国内外でも多く報告されています。
専門的な知識があれば、簡単に実行できてしまう攻撃とされており、ECサイトの運営者は対策が必要です。

クロスサイトスクリプティング攻撃の仕組み


まず攻撃者は、脆弱性のあるWebサイトを見つけ、悪質なサイトへ誘導する罠(脆弱性のあるサイトへ誘導するスクリプトを含んだリンク)を仕掛けます。
ユーザーが悪質なサイトのリンクをクリックし、そこから見たいサイトを訪れることで、仕組まれていた罠が発動して攻撃が始まります。
攻撃の種類には、マルチウェア感染や個人情報漏洩、フィッシング詐欺などといった被害が挙げられています。
このように、サイトをまたいでスクリプトが実行されるので「クロスサイト」という名称になっています。

クロスサイトスクリプティング攻撃の原因


本質的な原因は、攻撃者がWebサイトに不正なスクリプトを混入できてしまうということです。つまり、クロスサイトスクリプティングに対する脆弱性をもったまま可動しているサイトの放置が問題となっています。
不正なスクリプトには、個人情報を悪質なサイトに送信するように設定されているので、直接的な被害を生み出してしまいます。

クロスサイトスクリプティング攻撃の対策


個人情報の漏洩など、甚大な被害を及ぼすクロスサイトスクリプティング。
Webサイト運営者とユーザー、双方でのセキュリティ対策が必要です。

ユーザー側に求められる対策

まずは、使用しているブラウザやアプリを常に最新の状態にアップデートしておくことです。古いバージョンのままだと、何らかの脆弱性を抱えている場合があり、セキュリティも万全とは言えません。
他にも、不正なスクリプトを検出してくれる個人ユーザー向けのウイルス対策ソフトなどもあるので、それらを導入して不正なアクセスをブロックしましょう。

Webサイト運営側に求められる対策

生年月日の入力フォームのように、特定の範囲の数値しか入力できないようにすることで、スクリプトが入り込む隙をなくすことができます。このように、特定の文字以外の入力を受け付けない設定のことを、バリデーション処理といいます。
また、入力する文字数を制限することで、長いコードの入力も防ぎ、攻撃をある程度抑えることができます。バリデーション処理を行う際は、ブラウザ側で設定を行うとユーザーがその機能を無効化できてしまうので、必ずサーバー側で処理を行う必要があります。

SQLインジェクションとは?


SQLインジェクションとは、アプリケーションの脆弱性を利用して行われるサイバー攻撃の1つです。
そもそも「SQL」とは、データベースを操作するための言語で、データの更新や追加・ユーザー権限の付与などをする際に使用されます。
アプリケーションの脆弱性により、本来の意図ではない不当な「SQL」が作成さることで、データを不正に操作されてしまいます。

SQLインジェクション攻撃の仕組み


まず、攻撃者はWebアプリケーションサーバー内で、入力フォームからSQL文を含む文字列を入力します。そこで入力されたものはサーバーに渡され、脆弱性などを悪用して不正なSQLが実行されることで攻撃が始まります。
攻撃の種類には、データベース内のデータの消去や改ざんなどが挙げられます。

SQLインジェクション攻撃の原因


Webアプロケーション自体が不正アクセスに気付けず、外部から侵入してきたSQL文が実行されてしまうということが、根本的な原因です。
本来であれば、Webアプリケーションに不正なアクセスがあった場合、正しい処理が実行されるます。
しかし脆弱性がある場合、SQL文を誤った命令文として認識することで適切な処理が行われず、データベースの悪質な操作が可能になってしまいます。

SQLインジェクション攻撃の対策


根本的な対策として、安全なWebサイト・Webアプリケーションを開発することが挙げられます。あらかじめ設計や製造段階からセキュリティを考慮し、SQLインジェクションの脆弱性が存在しないサイト等を制作することで対策が可能です。
また、SQLの構文が変更されることが原因なので、ユーザーから想定外の情報が入力されてもそのまま処理せず、正しい処理を実施することが重要となります。

まとめ


クロスサイトスクリプティング(XSS)は、脆弱性のあるサイトを利用し、個人情報漏洩やフィッシング詐欺などを目的としています。
一方、SQLインジェクションは、不正なコードを作成することでデータの消去や改ざんなど、データベースを攻撃することが目的です。
目的は違いますが、いずれにせよECサイト運営者のセキュリティ対策が求められています。
それぞれの特徴をよく理解し、未然に防いでいきましょう。

株式会社Refineでは、プライバシーマークを取得しており、適切なセキュリティ対策をした実装と構成をご提案する事で、
みなさまのECサイトのセキュリティ対策を支援いたします。

ECサイトのセキュリティのご相談はこちら

ピックアップ記事

  1. ECサイト運営で定点観測すべき指標とは?
  2. 5つの業界におけるファネル分析の例とケーススタディ
  3. 商品毎の売上トレンドを数クリックで可視化する!
  4. ファネル分析で ECサイトの売上アップ

関連記事

  1. ECサイト

    サイトが繋がらなくなったら開発ベンダーに確認すべきこと

    前回は、ECサイトが繋がらなくなったときにやるべきことについてお話…

  2. ECサイト

    EC-CUBEとSalesforceでできるインバウンドマーケティング

    ECサイトを運営していれば自然と膨大な量が集まる顧客リスト。その顧…

  3. ECサイト

    薬機法、EC事業者は知らないと危ない?

    健康食品や化粧品、サプリメントを取り扱うEC事業者は、薬機法を知らな…

  4. ECサイト

    これからは個人の時代?D2CとP2Cの違いとは

    今まではメーカーから卸、小売店を介する販売形態だったのに対して、EC…

  5. ECサイト

    ECサイトとインスタグラム

    SNSで一般的なのは、Line、Facebook、twitterですが…

  6. ECサイト

    購買率を高める!レコメンドエンジン

    実店舗スタッフに趣味嗜好のヒアリングを受けて、自分好みの商品を提案され…

最新の記事

  1. ECサイト

    ECサイト、何でつくる?ECプラットフォーム別費用比較
  2. ECサイト

    ECカートプラットフォーム徹底比較!EC-CUBEとecforceの違いとは?
  3. ECサイト

    EC-CUBEとShopifyの違い -ECサイトの種類-
  4. ECサイト

    Shopifyで連携できるCRM -Salesforce Sync-
  5. ECサイト

    ShopifyとEC-CUBEの違い -仕様の差-
PAGE TOP