- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我遇到了一个相当奇怪的问题。
我们有一个 MySql 数据库在我们的 C#/Asp.Net 网络应用程序后面运行。
我们为每个查询使用参数以防止 SQL 注入(inject)攻击。
但是,我们最近从一个客户那里收到了奇怪的 SQL 错误。
经调查,我们发现客户一直在将包含“右单引号”(’) 字符的地址粘贴到我们网站的字段中。
令人惊讶的是,这似乎通过了我们代码的参数化部分,并被插入到查询中,因此我们的 MySQL 服务器将其解释为未转义的引号。
这意味着我们的客户在不知不觉中对我们的服务器执行了 SQL 注入(inject)攻击。
我有两个问题:
1) 这不是非常不安全吗?如果这对我们不利,是否还有其他公司可能会受到同样的安全漏洞的影响?
2) 我该如何解决这个问题?在参数化用户输入之前,是否有任何方法可以在不运行正则表达式或字符串替换的情况下清理此输入? (考虑到代码库的规模和我们拥有的编码人员的数量,这可能需要一个月的工作量)。
我们一直认为参数化可以防止集中的恶意攻击。不是这样吗?
规范:MySQLServer 5.6
MySql .Net 连接器 1.0.10.0
ASP.NET 4.5.1
感谢任何帮助或建议...
最佳答案
我认为问题在于 SQL Server 默认将命令视为 unicode,因此当您的 MySQL 数据库使用 ASCII 时,ASP.NET 不会费心清理 unicode 字符。
根据 this question ,应该可以通过使用以下命令更改您的表以允许正确的单引号:
ALTER TABLE [Table] COLLATE='utf8_unicode_ci';
来自 MySQL 文档 here ,看起来你可以在运行时为整个服务器设置字符集和排序规则模式。要测试它是否解决了您的问题,请尝试像这样启动 MySQL:
mysqld --character-set-server=utf8 --collation-server=utf8_unicode_ci
关于c# - 右单引号 (Unicode :(U+2019) Extended Ascii 146) causes SQL injection through MySqlParameter,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32891739/
在线编写 yacc 代码的教程使用单引号表示分号和其他字符: ';' '+' '-' (etc) 但是在使用时: '' 在我将其更改为双引号之前,我遇到了错误: "" 相似地, '>=' '==
MySQL documentation说它应该是\'。然而,scite 和 mysql 都显示 '' 有效。我看到了,它有效。我该怎么办? 最佳答案 您引用的 MySQL 文档实际上比您提到的要多一些
MySQL documentation说它应该是\'。然而,scite 和 mysql 都显示 '' 有效。我看到了,它有效。我该怎么办? 最佳答案 您引用的 MySQL 文档实际上比您提到的要多一些
MySQL documentation说它应该是\'。然而,scite 和 mysql 都显示 '' 有效。我看到了,它有效。我该怎么办? 最佳答案 您引用的 MySQL 文档实际上比您提到的要多一些
MySQL documentation说它应该是\'。然而,scite 和 mysql 都显示 '' 有效。我看到了,它有效。我该怎么办? 最佳答案 您引用的 MySQL 文档实际上比您提到的要多一些
我一直在使用 SED (Bash shell) 转义单引号问题。 我需要做 $cfg['Servers'][$i]['password'] = ''; 进入 $cfg['Servers'][$i]['
需要将'替换为\'但这就是我得到的: >>> s = "It's nice to have an example" >>> s.replace("'", "\\'") "It\\'s nice to
我在处理连接字符串中的 ' 字符时遇到问题。 Entity Framework 抛出异常说: Format of the initialization string does not conform
我遇到了一个非常奇怪的问题,我无法设置 Content-Security-Policy 所需的单引号。我假设我运行的是旧版本的 ingress,它仅在我禁用并重新启用它 (microk8s) 后才得到
插入带有撇号的值的正确 SQL 语法是什么? Insert into Person (First, Last) Values 'Joe', 'O'Brien' 我不断收到错误,因为我认为
我有三列数据 selector label option list time you personally
我使用 Java Pattern 类将正则表达式指定为字符串。 举个例子我喜欢成为蜘蛛侠:“彼得·帕克” 应将蜘蛛侠和“Peter Parker”列为单独的标记。谢谢 try { Buffe
我正在尝试删除标记 ' (单引号)但我不知道如何。 我在做delm \'但它不起作用。我也尝试了我能想到的所有组合。 我意识到这更像是一个 Vim 脚本问题,但我在任何地方都找不到。 最佳答案 为什么
如何禁用红色突出显示的特定实例。 我尝试在单引号前输入转义符,但没有成功。我确信单引号导致了红色突出显示,因为当我删除它时,它就会消失。 代码如下: import React from 'react'
我需要输出单引号 (')。它必须是单引号而不是 ',因为这是用于向 jquery 函数提供数据的字符串的一部分。 我使用 C# 循环遍历一个对象来构建一个字符串 "var data = [['Item
我正在尝试: "l'ape"); ?> var my_javascript_object = jQuery.parseJSON(''); 我收到此错误“未捕获的语法错误:意外的标识符”。问题是
我的问题是关于传递给方法验证的“add\”反斜杠单引号,该反斜杠单代码有什么用? document.writeln('\',\'N\'))>'); 最佳答案 欢迎来到堆栈溢出。 反斜杠告诉代码这不是引
我要执行命令: xcodebuild -exportArchive -exportFormat IPA -archivePath myApp.xcarchive -exportPath myApp.i
我有一个字符串,里面有一个 ': example link text 不幸的是,这似乎不起作用。 Firebug 提示“SyntaxError:参数列表后缺少 )”,您可以看到 HTML 实体已被 '
据我所知,'mars%22%3A%22' 和 "mars%22%3A%22" 是等效的,因为没有任何内容被转义. 我创建 javscript 书签已经有一段时间了。有一次,当按原样粘贴到 Chrome
我是一名优秀的程序员,十分优秀!