select * from user where username=‘user’ and password=‘pass’
万能账号原理
当在登录界面输入 【万能账号】比如 a’ or true # 以后,后端会将输入的参数拼接到SQL中,然后去数据库中查询账号和密码,SQL语句大概是下面这样
select * from user where username=‘a’ or true #’ and password=’pass’
由于 # 在SQL中是注释符,注释符后面的内容不起作用,所以真正执行的SQL语句大概是下面这样
select * from user where username=‘a’ or true
or true 会使SQL语句恒成立,从而查询出数据库中的所有账号和密码,从而成功登录
注释符
除了 # 以外, -- 也是SQL中的注释符,但SQL的语法格式规定--和后面的注释内容必须间隔一个空格,所以这需要使用 a' or 1 -- a 而不是 a' or 1 -- 其原理和 a’ or 1 # 大同小异,拼接到SQL中大概是下面这样
select * from user where username=‘a’ or true — a‘ and password=’pass’
注释后面的内容不生效,真正执行的SQL大概是下面这样
select * from user where username=‘a’ or true
SQL语句恒成立,从而登录成功
换句话来说,a' or true -- a经过SQL的转化后,结果等价于 a’ or true #
比较运算符
SQL中规定,非布尔类型的数据参与比较运算时,会转化为布尔类型再参与运算。比如 or 1 或者 or 1=1 ,会转化为布尔类型的 true 再参与 or 的比较运算,也就是变成 or true ,同样能使条件恒成立,从而登录成功
简单来讲就是:a' or 1 # 或者 a' or 1=1 # 等价于 a' or true #
万能密码原理
当我们在登录界面输入 【万能密码】 比如 admin’ # 以后,后端会将输入的参数拼接到SQL中,大概是下面这样
select * from user where username=‘admin’ #’ and password=’pass’