位置: 编程技术 - 正文

MySQL解决SQL注入的另类方法详解(mysql注入的修复方式)

编辑:rootadmin

推荐整理分享MySQL解决SQL注入的另类方法详解(mysql注入的修复方式),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mysql报错注入,mysqlsql注入例子,mysql sql注入,mysql sql注入,mysqlsql注入例子,mysqli sql注入,mysql sql注入,mysqli sql注入,内容如对您有帮助,希望把文章链接给更多的朋友!

本文实例讲述了MySQL解决SQL注入的另类方法。分享给大家供大家参考,具体如下:

问题解读

我觉得,这个问题每年带来的成本可以高达数十亿美元了。本文就来谈谈,假定我们有如下 SQL 模板语句:

现在我们需要根据用户输入值填充该语句:

我们得到了下面的 SQL 语句,我们再提交给数据库:

问题在于,攻击者可以构造如下的用户输入值:

拼接好的最终语句就变成了:

攻击者成功地改变了模板语句的语义。这种问题不单单发生在 SQL 上,还出现在通常使用模板的任何语言上,比如 HTML 和 shell 脚本。

常规解决方案的说明

SQL 是具备任意性和一致性的公理,token 和派生规则构成其公理化基础。要注意的一个词语是「任意性」。与 SQL 等价的公理化数不胜数。对于这种任意等价的表示,每一条合法的语句都能被准确地映射到 SQL 里的合法语句,其它语言亦然。在这种任意等价表示中,如果某语句是不合法的,那么它在 SQL 里也是不合法的。攻击者不可能构造出可以满足任何可能的、任意与 SQL 等价的规则。

策略1:根据不同的派生规则,用另一种语法扩展模板语句

例子1:前缀语言

SQL 使用中缀表示法注1。中缀表示法等价于 lisp 风格的前缀表示法注2。中缀与前缀:

a、b、c 是标识符或值,OP1、OP2 是操作符或功能。

前缀表示法的示例语句:

该语句是等价的。它们在语义上属于外延。自动把 SQL 的中缀表示法转换成前缀表示法或其它表示法,都不算问题了。然而,攻击者的注入在前缀语法方面就是不合法的:

语法错误。攻击者想要的是:

这是不同的。攻击者的注入不能输出合法的前缀语言。

例子2:欧拉表示法

另一个替代方法将数得着欧拉表示法了。从中缀表示法到欧拉:

例子中的语句:

而注入的语句将出现语法错误:

攻击者本来是想写成:

攻击者正在做错误的事情。他的注入根本就没有注意到所选的任意标记法。

例子3:对象标记法(object notation)

MySQL解决SQL注入的另类方法详解(mysql注入的修复方式)

还有一种替代方法,对象标记法。从前缀表示法到对象:

例子的代码:

注入再一次折戟于语法:

我不再提供正确答案了,读者可以当做练习,看看攻击者应该写成什么样子。

策略2:为 SQL 选择其它任意 token

keyword 常常是一门语言里的任意 token。重要的是它们在派生规则里的位置、而非它们的任意体现。你总是可以用其它 keyword 替换现有 keyword,并且来回转换。举个例子,我们可以将下面 SQL 语句中的 keyword 转换成我们姑且称为「任意的 brainfuck」:

为了论证起见,我们将把操作数映射为 半任意的结构化序列:

phai1Oa6 是任意选取的字符序列。对于当前情形,例子:

变成了:

iph0ohKi ieZoh4xa aeZi5uja @phai1Oa6@T@ OoJ4aX4n @phai1Oa6@f1@ eeQu2Zad '{value1}' @phai1Oa6@and@ @phai1Oa6@f2@ eeQu2Zad {value2}

这是合法的、任意的 brainfuck 语言。经过注入之后,我们得到了:

iph0ohKi ieZoh4xa aeZi5uja @phai1Oa6@T@ OoJ4aX4n @phai1Oa6@f1@ eeQu2Zad 'anything' or 1=1 or a='whatever' @phai1Oa6@and@ @phai1Oa6@f2@ eeQu2Zad 5

你可以看到,它包含的 token 有 'or' 和 '=',它们在任意的 brainfuck 语言中是不合法的。我们的语法说,你必须这样使用:

这些 token 也不是操作数,因为它们将只能被视作:

换句话说,注入之后的语句就变得不合法、也不可用了。

策略3:验证不变量

你数数下面模板语句例子中的 token 有几个?

[1] select [2] * [3] from [4] T [5] where [6] f1 [7] = [8] '{value1}' [9] and [] f2 [] = [] {value2} 个。模板填充之后,总数必须仍然为 ,但是我们却看到了攻击者所引发的结果:

[1] select [2] * [3] from [4] T [5] where [6] f1 [7] = [8] 'anything' [9] or [] 1 [] = [] 1 [] or [] a [] = [] 'whatever' [] and [] f2 [] = [] 5

现在有 个 token 。违反这种不变量,就暴露了有问题的地方。同样适用于相同语句的表示,除了任意的、brainfuck 语言。模板的填充根本不可能导致 token 数量的变化。

事实上,你可以试着使用其它不变量,并在填充之后进行验证。攻击者必须和它们保持一致。

结论

有些人提倡,程序员在填充 SQL 模板时,应该更加小心。应对 SQL 注入问题,只是需要在编程方面多加小心。很明显,这种方式算不上解决方案。人们仍然在校验用户输入值方面出现错误,最终接受了带有恶意的用户输入值。换句话说,单凭我们所有人更努力地工作,是无法根本解决这种问题的。

真正的解决方案在于,SQL 语句本身的任意性,并要求所有现存不变量都符合任意的等价结构的规则。无需程序员的干预,就能自动完成。

攻击者不得不符合一种未知的、任意的 brainfuck 语法的规则。想要符合一组未知的规则,将是难以解决的问题。因此,攻击者通常无法得手。

更多关于MySQL相关内容感兴趣的读者可查看本站专题:《MySQL日志操作技巧大全》、《MySQL事务操作技巧汇总》、《MySQL存储过程技巧大全》、《MySQL数据库锁相关技巧汇总》及《MySQL常用函数大汇总》

希望本文所述对大家MySQL数据库计有所帮助。

MySQL性能瓶颈排查定位实例详解 本文实例讲述了MySQL性能瓶颈排查定位的方法。分享给大家供大家参考,具体如下:导读从一个现场说起,全程解析如何定位性能瓶颈。排查过程收到线

MySQL异常恢复之无主键情况下innodb数据恢复的方法 本文讲述了MySQL异常恢复之无主键情况下innodb数据恢复的方法。分享给大家供大家参考,具体如下:在mysql的innodb引擎的数据库异常恢复中,一般都要求有

如何配置全世界最小的 MySQL 服务器 配置全世界最小的MySQL服务器——如何在一块IntelEdison为控制板上安装一个MySQL服务器。介绍在我最近的一篇博文中,物联网,消息以及MySQL,我展示了如

标签: mysql注入的修复方式

本文链接地址:https://www.jiuchutong.com/biancheng/321321.html 转载请保留说明!

上一篇:MySQL修改my.cnf配置不生效的解决方法(修改mysql配置)

下一篇:MySQL性能瓶颈排查定位实例详解(mysql性能问题)

  • 个人所得税退还是不退好
  • 金税盘软件打不开
  • 未交增值税借方表示什么意思
  • 税务中的三费是指什么
  • 公司不交工会经费的原因,风险说明
  • 免税是不是不用交税
  • 企业所得税季度预缴怎么计算
  • 小微企业季度不超过30万怎么报增值税
  • 单独计价作为固定资产入账的土地为什么不计提折旧
  • 预缴增值税项目编号填写错误怎么办
  • 企业递延所得税费用的计算公式
  • 固定资产减少当月
  • 特许权使用费增值税征收品目
  • 销售返利增值税按哪个税率
  • 发生非正常损失的购进货物不准予抵扣的增值税
  • 吸收合并控股合并新设合并的区别
  • 营业外收入需要计提销项税吗
  • 担保预计负债要如何做账?
  • 产品质量赔款的账务处理
  • 福利费不交个人所得税会怎么样
  • 工会发票开了专票怎么办
  • 增值税和消费税申报对比不符怎么处理
  • 农产品一般纳税人免税吗
  • 2017年7月1日开始实施的税法新规
  • 如何看待餐饮企业文化
  • 对外投资公司经营范围
  • 增值税留抵退税政策解读
  • 冲暂估怎么做分录
  • windows hello用不了怎么办
  • efi bios u盘启动
  • 购入的车辆入账包括哪些费用
  • uniapp获取input的值
  • 在win7中,如何创建一个TXT文件
  • 在途物资属于什么科目借贷方向
  • 什么是主营业务税金及附加
  • 车辆运输费计入什么科目
  • 自查补缴增值税如何申报
  • 用友预收货款账务处理
  • 小企业会计准则调整以前年度费用分录
  • vue.js前端开发快速入门与专业应用
  • 职工教育经费可以以后年度结转吗
  • 流动资产处置利得
  • 图像的傅里叶变换和离散余弦变换实验报告
  • php curl_setopt
  • 增值税抵扣要求一一对应
  • lvm命令详解
  • ps笔刷在哪里调
  • 固定资产加速折旧是什么意思
  • 以非现金资产清偿债务的,债权人应当
  • 入库税款异常怎么处理好
  • 小规模纳税人享受小微企业优惠政策
  • 帝国cms插件编写教程
  • javatoolkit详解
  • 所有者权益股东权益区别
  • 哪些普通发票可以抵扣
  • 小规模纳税人申报增值税的操作流程
  • 营改增试点行业顺序
  • 如何处理固定资产报废
  • 发票逾期未抵扣怎么办
  • 2023年职工养老保险缴费标准
  • 特定担保债权
  • 固定资产转让开票大类是什么
  • 对公帐户发票金额是什么
  • winxp怎么做系统
  • ubuntu nginx webdav
  • 系统自带邮件
  • linux常用命令详解
  • 百分比的介绍
  • android studio打包jar文件
  • 配置命令提示符怎么打开
  • cmd 更改密码
  • unity 版本控制
  • 解决的英文
  • python enumeration
  • 广州地税预约网官网
  • 为什么购进固定资产不得抵扣
  • 企业未开立基本存款账户承诺书的相关规定
  • 征收两道消费税怎么算
  • 简述纳税人与负税的区别
  • 一般纳税人什么意思
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设