德阳| 景泰| 察哈尔右翼中旗| 淮阴| 潢川| 郴州| 大渡口| 个旧| 中方| 新邱| 湖口| 许昌| 灵台| 元江| 丰县| 沁源| 盂县| 白城| 金平| 汝城| 布尔津| 黄石| 监利| 玛沁| 青铜峡| 绥德| 涟源| 高淳| 信阳| 泸县| 丹棱| 新民| 金堂| 涉县| 永德| 昌平| 洪雅| 商南| 威县| 铜陵县| 鹤庆| 新田| 西丰| 富顺| 大方| 正阳| 图木舒克| 奎屯| 恩平| 盂县| 朔州| 淮安| 西安| 临澧| 汝州| 都匀| 江油| 南岳| 镇沅| 德清| 称多| 汉沽| 故城| 梁河| 环江| 坊子| 安乡| 新宾| 特克斯| 松溪| 梅河口| 江津| 洪洞| 砚山| 句容| 楚雄| 民权| 永德| 郎溪| 清涧| 英山| 自贡| 赫章| 高邮| 东阳| 边坝| 丹寨| 长乐| 克山| 交口| 长垣| 天水| 含山| 盐城| 金湖| 中阳| 济宁| 皮山| 溆浦| 高邮| 吉木乃| 八公山| 顺平| 新建| 衡南| 定边| 霍林郭勒| 翁源| 新源| 伊春| 延津| 突泉| 开封市| 桓仁| 元阳| 青白江| 剑河| 镇宁| 精河| 万年| 额济纳旗| 大埔| 合肥| 同江| 横县| 江源| 华安| 两当| 南川| 灵寿| 寒亭| 都安| 无锡| 攀枝花| 九台| 合江| 新和| 来宾| 赞皇| 南木林| 浙江| 会同| 西充| 徐闻| 定州| 广东| 龙胜| 泰顺| 若羌| 太白| 汝州| 江口| 杜集| 昌宁| 武冈| 留坝| 阳朔| 临夏市| 揭西| 文山| 洪江| 平谷| 印江| 含山| 朔州| 常德| 高邮| 黄梅| 龙山| 彭泽| 芜湖县| 阿荣旗| 定南| 巴马| 随州| 宁城| 北安| 襄阳| 民勤| 鄂托克前旗| 广灵| 双柏| 乐平| 正阳| 汨罗| 鱼台| 浮梁| 吉首| 龙泉驿| 西峡| 阳西| 沿滩| 天长| 平昌| 简阳| 扶沟| 北辰| 兴国| 灵寿| 涿鹿| 乌马河| 农安| 丰南| 丹江口| 西藏| 白水| 内蒙古| 都江堰| 马龙| 太仆寺旗| 崇礼| 长白山| 抚顺市| 金州| 南浔| 九江市| 洛隆| 冀州| 昌乐| 张家口| 通海| 饶河| 梁河| 代县| 青河| 独山子| 泰兴| 德庆| 兰考| 瓯海| 西华| 北海| 克山| 君山| 金秀| 蒙山| 花都| 大田| 永和| 单县| 隆子| 凤翔| 武昌| 九寨沟| 临安| 文县| 冠县| 西安| 宝应| 平凉| 新兴| 云阳| 大城| 含山| 井研| 陇川| 金山屯| 屏边| 同江| 永城| 五大连池| 荣县| 准格尔旗| 慈溪| 威尼斯人注册
|
|
51CTO旗下网站
|
|
移动端

强加密算法下,SQL注入案例

密码学具有各种优点,包括信息的机密性。然而,过度依赖密码学来保护应用程序是一个坏主意。今天我们就通过一个案例研究,来认识一下通过加密的有效载荷识别和利用SQL注入漏洞。

作者:xiaohui来源:嘶吼网|2018-12-18 09:06

密码学具有各种优点,包括信息的机密性。然而,过度依赖密码学来保护应用程序是一个坏主意。今天我们就通过一个案例研究,来认识一下通过加密的有效载荷识别和利用SQL注入漏洞。

SQL注入也许很多人都知道或者使用过,如果没有了解或完全没有听过也没有关系,因为接下来我们将介绍SQL Injection。

SQL注入,就是通过把SQL命令插入到Web表单递交或输入域名或页面请求的查询字符串,最终达到欺骗 服务器 执行恶意的SQL命令。

具体来说,它是利用现有应用程序,将恶意的SQL命令注入到后台 数据库 引擎执行的能力,它可以通过在Web表单中输入恶意SQL语句得到一个存在安全漏洞的网站上的数据库,而不是按照设计者意图去执行SQL语句。

那SQL注入会在什么时候发生呢?

假设我们在浏览器中输入URL www.sample.com,由于它只是对页面的简单请求无需对数据库动进行动态请求,所以它不存在SQL Injection,当我们输入www.sample.com?testid=23时,我们在URL中传递变量testid,并且提供值为23,由于它是对数据库进行动态查询的请求(其中?testid=23表示数据库查询变量),所以我们可以在该URL中嵌入恶意SQL语句。

不过要提前说明一下,我们不会在本文中讨论加密问题,而是只讨论应用程序缺陷,我们会先生成加密的有效载荷,然后将其用于识别和利用SQL注入。

在最近我们接触到的一个电子商务应用程序中,观察了该网站的大多数请求参数值已被加密。当请求参数被加密时,很难对应用程序进行模糊测试,除非我们可以去除加密,不过这需要知道密钥和加密算法。

下图就是我们所找的样本网站的详细信息页面,该页面就是以加密格式发送id(orderid)参数的。

注意:参数值(BDKfx3xNKsc =)是加密的,而不是简单的base64编码。ID参数的加密值以base64编码格式表示。

我们还注意到,如果我们退出应用程序,然后以相同的用户登录并导航到完全相同的页面,则加密参数(nPBri1km2ic =)的值现在不同,如下所示。

正如上图所示,随机密钥在每个成功的登录或会话ID(cookie的一部分)中用于加密,以某种方式用作密钥的一部分。这看起来很安全,不过还是让我们尝试着SQL注入。

首先,我们尝试在多个位置注入单引号(')以测试输入验证,但请求参数被拒绝,因为这些参数需要加密格式(即有效的密文)。

不过我们在这里可以使用购物车的一个分享功能,此功能允许用户与其他人共享购物车项目。当用户保存购物车进行共享时,会产生一个带有随机查询令牌的链接。通过访问此链接(URL),用户可以访问彼此的购物车。在购物车被要求保存之前,用户被要求在购物车上标记一个名字。

由于这是接受明文输入的罕见输入字段之一,所以我们将其编码为SQLi,XSS。在更深入的检测中,我们发现生成的URL中的令牌共享购物车实际上是我们为购物车选择的购物车名称的密码。

不过请注意,共享购物车功能可不会轻易受到任何攻击的影响,但可以用于为给定输入(明文)生成加密的有效内容(密文)。现在,可以共享购物车功能的链接就可以生成一个加密的攻击有效载荷来检查应用程序对SQL注入,绕过授权等漏洞行为进行验证了。为了测试SQL注入,生成了单引号(')的加密值。

加密的有效载荷用于模糊仅接受密文值作为输入的各种应用参数。我们花了一些时间来打到正确的位置,但是最终,orderitem页面的ID参数返回一个SQL错误消息,确认该漏洞。

该错误消息证明应用程序生成动态查询,并可能容易受到SQL注入攻击。现在是从数据库中提取信息的时候了,基于UNION的SQL查询用于从数据库中提取数据,联合运算符用于组合两个或多个select语句的结果。

第一个任务是确定作为SQL查询的一部分返回的列数,使用试错,我们在查询中返回了一些列(30)。现在是时候从数据库中提取信息了,我们创建了一个加密的有效载荷来提取数据库版本信息,如下所示。

然后,把上述有效载荷的输出生成的密文作为页面上易受攻击的ID参数输入。

然后我们使用这个漏洞来构建数据库系统,最终得到一个shell。

总结

由上面的分析可知,用加密参数来实现应用程序中的安全性其实并不像想象中的那么安全,比如用强加密算法加密的数据,恶意攻击者可以使用加密的有效载荷的方式来进行攻击。 目前,加密仍被认为是保护数据免遭篡改或欺骗的有力机制,不过由于加密执行不力和缺乏明确的使用隐私保护,所以仍有可能会造成相当危险的安全漏洞。

【编辑推荐】

  1. 如何做好漏洞管理的漏洞修复工作
  2. 应用安全:Web攻击手段及防御之—网络层或漏洞
  3. 漏洞银行CTO张雪松:我们需要用“开放安全”新视角拥抱安全
  4. Firefox被曝出一个已存在 11 年未修复的漏洞
  5. SQL注入常规Fuzz全记录
【责任编辑:赵宁宁 TEL:(010)68476606】

点赞 0
分享:
大家都在看
猜你喜欢

读 书 +更多

J2EE应用开发(WebLogic+JBuilder)(第二版)

本书介绍如何将最流行的J2EE应用服务器WebLogic Server和最好的Java集成开发工具JBuilder结合起来开发J2EE应用,主要内容包括:WebLogic Se...

订阅51CTO邮刊

点击这里查看样刊

订阅51CTO邮刊
高家辛庄子 玉兰村 古恰乡 茅山后村 孝友里
大校场 黎少镇 西桑庄村村委会 晨阳道帝旺温泉花园雨花居 旧闫村
葡京娱乐网 澳门威尼斯人官网 澳门威尼斯人官网 新濠天地网上游戏 澳门威尼斯人网址
澳门大发888娱乐 庄闲游戏注册 威尼斯人官方网站 澳门威尼斯人官网 网上信誉赌场
澳门赛马会赌场官网 威尼斯人赌博官网 葡京网上赌场 澳门威尼斯人官网 澳门星际
希尔顿赌博网址开户 澳门真人网站平台 澳门永利官网 澳门威尼斯人网址 澳门网络赌场网址