質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

基本情報技術者

基本情報技術者とは、経済産業省が行う国家資格「情報処理技術者試験」の区分の一つです。試験ではプログラマーやシステムエンジニアなどIT業界で働くために必要とされる基礎知識や情報処理において論理的な考え方ができるか等が問われ、企業から高い評価を獲ることができ、IT業界の入門的な資格として人気があります。

Q&A

解決済

3回答

1199閲覧

SQLインジェクションについて

sanezane

総合スコア91

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

基本情報技術者

基本情報技術者とは、経済産業省が行う国家資格「情報処理技術者試験」の区分の一つです。試験ではプログラマーやシステムエンジニアなどIT業界で働くために必要とされる基礎知識や情報処理において論理的な考え方ができるか等が問われ、企業から高い評価を獲ることができ、IT業界の入門的な資格として人気があります。

0グッド

1クリップ

投稿2018/02/28 12:04

基本情報技術者試験へ向けて勉強していてSQLインジェクションの説明のSQL文で理解できない点があるので質問させていただきます。

ログインする際IDとパスワードで認証するシステムで

`ID:ABCDEF Pass:'OR 1 = 1 --'

と入力するとSQLが

SELECT * FROM 会員表 WHERE ID = 'ABCDEF' AND Pass = '' OR 1 =1 --''

となり1 = 1が必ず真となるのでID、Passともに任意となってしまう。

という説明でしたが、この場合ID = 'ABCDEF'のANDは 1 = 1が入ってしまっている時点で有効でないのでしょうか。
ANDがあるから IDはABCDEFじゃないと入れないんじゃないの?という認識なのですが、1=1が入ってしまっている時点でWHEREに対する条件はtrueとなるということなのでしょうか。
SQLも基本は勉強したのですが、不慣れなためご教授いただければ幸いです。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答3

0

OR演算子よりもAND演算子のほうが優先度が高いため、
AND演算子で結合されている方を先に評価します。
ID = 'ABCDEF' AND Pass = ''
の結果がFALSEだとしても
ORで結合される
1 =1
がTRUEなので
ORは一方がTRUEなら結果TRUEなので成立してしまう、
っていう話です。

詳しくは、例えば
MySQL :: MySQL 5.6 リファレンスマニュアル :: 12.3.1 演算子の優先順位
4.2. 評価式
SQL演算子
など各処理系での優先順位・評価順位に関する記述も併せてお読みください。

投稿2018/02/28 12:10

編集2018/02/28 12:20
退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

sanezane

2018/02/28 12:25

リンクまで貼っていただきましてありがとうございます! おかげさまで理解できました!
guest

0

ベストアンサー

評価順の問題です。
まずID = 'ABCDEF' AND Pass = ''が評価されます。その結果が確定したあと、(結果) OR 1 = 1の評価に入ります。

最初の結果がTRUEならもとより、FALSEでもORの後がTRUEなので、全体の結果としては必ずTRUEになります。

投稿2018/02/28 12:17

swordone

総合スコア20651

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

sanezane

2018/02/28 12:23

評価順という意味がようやく理解できました。 ID = 'ABCDEF' AND Pass = '' OR 1 =1 --''を一つのANDの式として見ていました。 ありがとうございます!
guest

0

ANDで挟まれた条件は両方とも満たされないとTrueになりません。ORの場合は片方でOKです。本件では組み合わせなので優先順位に基づいて判定されます。

投稿2018/02/28 12:12

HogeAnimalLover

総合スコア4830

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

sanezane

2018/02/28 12:24

優先順に評価しているということが理解できまた! ANDの中にORが入っているのかと、勘違いしていました。 ありがとうございます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問