AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 50699
Accepted
Chris
Chris
Asked: 2009-08-06 16:11:22 +0800 CST2009-08-06 16:11:22 +0800 CST 2009-08-06 16:11:22 +0800 CST

你能让 MS Sql Server 拒绝所有匹配特定模式的查询吗?

  • 772

我想知道您是否可以让 Sql Server 查看传入的查询字符串并拒绝与特定模式匹配的查询字符串。换句话说,对于某一类查询(可能由正则表达式标识),我想知道是否可以让 Sql Server 返回错误消息,而不是像往常一样处理它们。

更具体地说,并给出一个潜在的用例,请考虑对 Sql Injection attack 的描述。如果我的网站受到这些技术的持续攻击,并且如果修补网站看起来是一个漫长的过程,那么(如果 Sql 允许的话)尝试通过在 Sql 中放入一些基本上说

如果查询与正则表达式CAST(0x[0-9A-Za-z]{20,}匹配,则不要执行它!

我的猜测是,如果这种过滤是可能的,那么这样做需要编写某种自定义的 Sql Server 加载项 DLL。但也许您可以使用 Sql Server 2008 的内置审计功能来做类似的事情?我真的不知道,我不确定文档中的哪个位置是开始查找的最佳位置。

如果你想指出为什么数据库是一个试图阻止 sql 注入攻击的愚蠢地方,那很好。但我的主要问题不是在这个特定用例中这是否是一个好主意,而是这种查询过滤/拒绝是否可能。

sql-server sql-server-2008 query
  • 3 3 个回答
  • 712 Views

3 个回答

  • Voted
  1. Cory
    2009-08-06T21:25:17+08:002009-08-06T21:25:17+08:00

    不,您不能让 SQL Server 拒绝基于某些模式匹配的语句。如何拒绝所有用户的 SELECT 权限并强制他们使用您创建的存储过程来访问基础表中的数据?只要您很好地验证了存储过程的输入,您应该是相当安全的。

    • 3
  2. Best Answer
    Dave Forgac
    2009-08-06T16:34:41+08:002009-08-06T16:34:41+08:00

    你的预感是正确的:数据库是解决这个问题的错误地方。SQL 注入起作用的全部原因是这些命令是有效的 SQL。通常,当您的应用程序将查询传递给数据库服务器时,特殊字符已转换回普通文本。

    如果您不想在应用程序级别缓解此问题,那么您应该研究软件防火墙解决方案,例如 dotDefender。在我看来,这也是在错误的地方攻击问题,最终会通过防火墙的逻辑。

    • 2
  3. mrdenny
    2009-08-06T17:42:37+08:002009-08-06T17:42:37+08:00

    不,没有办法让 SQL Server 基于模式匹配拒绝命令。要执行此类操作,您必须编写一个侦听器来接受 SQL 命令,检查它们,然后将它们传递给数据库引擎执行。

    你最好在应用层处理这个。

    • 1

相关问题

  • sql server 连接字符串上的网络数据包大小以提高吞吐量

  • 基于 Microsoft 的服务器(IIS、MSSQL 等)上的病毒扫描应排除哪些内容?

  • SQL 洗衣清单

  • OPENROWSET、二进制文件、varchars 和 varbinaries

  • 聚集索引与非聚集索引?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    从 IP 地址解析主机名

    • 8 个回答
  • Marko Smith

    如何按大小对 du -h 输出进行排序

    • 30 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    Windows 中执行反向 DNS 查找的命令行实用程序是什么?

    • 14 个回答
  • Marko Smith

    如何检查 Windows 机器上的端口是否被阻塞?

    • 4 个回答
  • Marko Smith

    我应该打开哪个端口以允许远程桌面?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    MikeN 在 Nginx 中,如何在维护子域的同时将所有 http 请求重写为 https? 2009-09-22 06:04:43 +0800 CST
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    0x89 bash中的双方括号和单方括号有什么区别? 2009-08-10 13:11:51 +0800 CST
  • Martin Hope
    kch 如何更改我的私钥密码? 2009-08-06 21:37:57 +0800 CST
  • Martin Hope
    Kyle Brandt IPv4 子网如何工作? 2009-08-05 06:05:31 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve