首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >sql注入。“'OR 1=1 #”和“‘OR 1=1 --”有什么区别?

sql注入。“'OR 1=1 #”和“‘OR 1=1 --”有什么区别?
EN

Stack Overflow用户
提问于 2018-09-02 15:00:42
回答 2查看 11.7K关注 0票数 3

有几个版本的sql注入方法,但我不知道为什么会有细微的差异。我如何知道不同环境之间的区别?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2018-09-02 22:30:36

TL;DR - # 表单仅在MySQL上可用。 -- 表单可用于任何品牌的SQL.

#--都用于引入注释。在SQL注入攻击中,这两者的目的都是为了确保该行的其余部分被忽略。

代码语言:javascript
运行
复制
SELECT * FROM MyTable WHERE name = '$unsafe_variable' AND id = 12345

SQL注入攻击可能会干扰$unsafe_variable,但查询仍将限于具有特定id的一行。但是,如果SQL注入攻击可以有效地中和第二个术语呢?

代码语言:javascript
运行
复制
SELECT * FROM MyTable WHERE name = '' OR 1=1 -- ' AND id = 12345
                                    ^^^^^^^^^^^^

超过--的任何内容都是注释,因此查询将忽略它。注释包含的内容看起来更像SQL语法,这并不重要。

--是标准ANSI SQL指定的唯一注释语法,所有SQL实现都应支持此语法。

但大多数SQL实现都支持其他注释语法,因为开发人员更熟悉它的使用。值得注意的是/* comment */语法,因为它允许多行注释,并且许多其他编程语言都支持它。

我检查过的所有SQL品牌都支持-- comment/* comment */

只有MySQL支持# comment语法。

只有Informix才支持{ comment }语法。

票数 4
EN

Stack Overflow用户

发布于 2018-09-02 15:31:09

简单地说,这是不同的数据库引擎的语法“或1=1 #”它适用于mysql,因为那里的注释使用#但使用“或1=1 -”与sql server BD一起使用,因为注释使用--有关sql注入方法示例的更多详细信息,请查看此link

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52134712

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档