SQL 全文索引和 SQL 注入

如何解决SQL 全文索引和 SQL 注入

将全文索引的使用公开给内部用户和可能的公共用户是否有任何已知的危险?

假设查询参数化正确,用户是否可以滥用输入来触发 sql 注入或拒绝服务攻击?

{{1}}

这个问题的触发因素是用户可以指定的输入种类繁多,而且不同的 sql 服务器具有不同的查询语法,如果指定的查询无效,至少有一些 (MysqL) 会返回语法错误

  • 'FORMSOF(INFLECTIONAL,模型 NEAR 飞机)'
  • 'NEAR((term1,term2),5) AND term3'
  • 'NEAR((term1,5) OR NEAR((term3,term4),2,TRUE)'
  • '+join +(>left
  • '电动 INPATH (/purchaSEOrder/items/item/comment)'

解决方法

在谈论 SQL 注入时,风险在于有人可以通过将 SQL 添加到数据参数来将 SQL 关键字引入查询本身。

这就是为什么分离数据和查询是绝对关键的。这通常通过使用占位符值来实现,如:

SELECT * FROM content_table WHERE MATCH(Title,Subtitle,Body) AGAINST (?);

就搜索而言,您通常需要注意两个层面:

  • 使用原始 SQL 关键字来表达查询条件的 SQL 层,例如 WHERE x=? AND y=?
  • 您在字符串中表达条件的搜索层,例如 WHERE CONTAINS(?) 具有绑定数据参数 '"computer software" NEAR hardware)'

请注意,第二种形式的语法包含在字符串中,因此如果您表明自己没有 SQL 注入的风险,但最终可能会收到很多由不良用户引起的语法错误您需要处理的输入。

在第一种情况下,如果您需要编写查询条件,则需要遵循通常的规则:

  • 不允许:
    • 在查询中包含未知字段。
    • 在查询中包含未知运算符。
  • 尽可能严格地将查询和数据分开。

您可能需要将请求的数据解析为可以重组为 SQL 查询的组件。这可能会变得很混乱,尤其是当您在搜索内容方面有很大的自由度时,因此请尝试使其尽可能简单和可测试

如果您有单元测试,请包含一个故意敌对并试图将无效或注入类型数据引入查询的测试。确保正确包含数据。

注意:如果您使用占位符值调用存储过程,但该存储过程使用串联组合 SQL 语句,您仍然处于危险之中,因此您需要绝对确定您将数据与查询分开.如果您的查询中引入了 个用户数据,则不存在 SQL 注入的风险。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?