V9.0 SQL注入漏洞

2023-12-22 21:36
文章标签 sql 漏洞 注入 v9.0 database

本文主要是介绍V9.0 SQL注入漏洞,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、漏洞介绍

近期,长亭科技监测到猎鹰安全(原金山安全)官方发布了新版本修复了一处SQL注入漏洞。xpc可以检测该漏洞,就想着获取一下poc,并且分析一下漏洞原理。

二、poc获取

xpoc虽然不开源,但是发包总是可以抓的。所以就进行了扫描,然后抓包,结果异常的顺利拿到了poc。

image.png

三、漏洞原理

  1. 首先官网下载试用安装包。

    下载网址:http://duba-011.duba.net/netversion/Package/SecManage.iso

  2. 解压安装居然挑环境,只能在windows sever上进行安装,所以这里又在下载了windows sever 2012的镜像,重新安装顺利成功。

    iso解压之后SecManage.exe就是管理中心的安装包,在对应系统上安装就可以了。

    image.png

    安装成功之后登陆界面如下,访问6868端口:

    image.png

  3. 安装过程中可以看到文件释放的位置C:\SecManage下面。

    image.png

  4. 安装好了,也可以登录了,当然是验证一下存不存在漏洞,流量代理到burp

    image.png

    发现无论怎么尝试都是返回数据格式错误。版本是V9.SP1.E1001 ,版本是包含在漏洞版本之内的。

  5. 反正都是要看代码的,所以就直接找到C:\SecManage\Console\inter\update_software_info_v2.php出现漏洞的文件。

    出现问题的代码就在这里, 当$postdata['type'] 是否不为 null 且不为空字符串。如果满足条件,它会将 $postdata['type']的值赋给$id 变量,然后将 "and type=$id" 添加到 SQL 查询条件的 $where 中。而下面sql语句就是直接将$where拼接而成,猜测就是这里没有过滤导致可以触发sql注入漏洞。

    image.png

    回到这段代码开始部分,首先定义了一个 $paramArr 数组,其中包含了需要检查的参数名。然后,它使用 checkParam 函数来检查这些参数。在检查后,如果 $check 数组中存在 nResult 键,那么它会意味着参数检查失败,会设置一个包含错误信息的 JSON 响应,并退出脚本。看到了返回数据格式错误字段。

    image.png

  6. 全局搜索checkParam函数,找到路径C:\SecManage\Console\inter\common\checksql.php文件

    checkParam函数,它用于检查传递给它的参数数组 $postData 中是否包含指定的键,以及一些其他的验证。checkParamFull 函数用于检查参数的完整性,它会遍历 $keyData 数组中指定的键,并检查是否都存在$postData 数组中。如果有任何一个键缺失,它将返回 false,否则返回 true。如果参数不完整,它还会记录错误日志。

    image.png

    接下来,它调用 checksql 函数来检查 $postData 数组中的值是否包含SQL注入,如果检查到SQL注入,它返回一个包含 "nResult" 键值为25的数组,表示SQL注入检测到。

    看一下具体代码:

    首先,它检查传入的参数 $param 是否为数组或对象。如果是数组或对象,它会递归调用 checksql 函数,以确保所有数组元素或对象属性都经过相同的检查。

    接下来,它检查是否存在名为 "checkWhiteList.php" 的文件,并在该文件中定义了$checkWhiteList 变量。如果文件存在并且$param 的值在白名单中,它会执行一系列操作,包括添加反斜杠转义、删除一些特殊字符、处理换行符、将HTML标签转义等。这些操作旨在防止一些常见的攻击。

    然后,它使用正则表达式检查 $param 是否包含潜在的SQL注入攻击字符串,如果匹配到,返回 true。则提示错误信息。

    image.png

  7. 所以到这里也就结束了,可以从代码中猜测,存在漏洞的版本应该是没有对参数做单独的sql注入检测或者检测注入的方式不对,导致存在漏洞,而现在官网下载的版本,虽然在受影响范围内,但是已经修复了该漏洞。当去掉这里的检测是可以触发该漏洞。

    image.png

免费领取安全学习资料包!

渗透工具

技术文档、书籍

 

面试题

帮助你在面试中脱颖而出

视频

基础到进阶

环境搭建、HTML,PHP,MySQL基础学习,信息收集,SQL注入,XSS,CSRF,暴力破解等等

 

应急响应笔记

学习路线

这篇关于V9.0 SQL注入漏洞的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/525563

相关文章

Mysql的主从同步/复制的原理分析

《Mysql的主从同步/复制的原理分析》:本文主要介绍Mysql的主从同步/复制的原理分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录为什么要主从同步?mysql主从同步架构有哪些?Mysql主从复制的原理/整体流程级联复制架构为什么好?Mysql主从复制注意

Python中文件读取操作漏洞深度解析与防护指南

《Python中文件读取操作漏洞深度解析与防护指南》在Web应用开发中,文件操作是最基础也最危险的功能之一,这篇文章将全面剖析Python环境中常见的文件读取漏洞类型,成因及防护方案,感兴趣的小伙伴可... 目录引言一、静态资源处理中的路径穿越漏洞1.1 典型漏洞场景1.2 os.path.join()的陷

如何解决Druid线程池Cause:java.sql.SQLRecoverableException:IO错误:Socket read timed out的问题

《如何解决Druid线程池Cause:java.sql.SQLRecoverableException:IO错误:Socketreadtimedout的问题》:本文主要介绍解决Druid线程... 目录异常信息触发场景找到版本发布更新的说明从版本更新信息可以看到该默认逻辑已经去除总结异常信息触发场景复

MyBatis编写嵌套子查询的动态SQL实践详解

《MyBatis编写嵌套子查询的动态SQL实践详解》在Java生态中,MyBatis作为一款优秀的ORM框架,广泛应用于数据库操作,本文将深入探讨如何在MyBatis中编写嵌套子查询的动态SQL,并结... 目录一、Myhttp://www.chinasem.cnBATis动态SQL的核心优势1. 灵活性与可

MySQL 表的内外连接案例详解

《MySQL表的内外连接案例详解》本文给大家介绍MySQL表的内外连接,结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录表的内外连接(重点)内连接外连接表的内外连接(重点)内连接内连接实际上就是利用where子句对两种表形成的笛卡儿积进行筛选,我

MySQL的ALTER TABLE命令的使用解读

《MySQL的ALTERTABLE命令的使用解读》:本文主要介绍MySQL的ALTERTABLE命令的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、查看所建表的编China编程码格式2、修改表的编码格式3、修改列队数据类型4、添加列5、修改列的位置5.1、把列

Mybatis嵌套子查询动态SQL编写实践

《Mybatis嵌套子查询动态SQL编写实践》:本文主要介绍Mybatis嵌套子查询动态SQL编写方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、实体类1、主类2、子类二、Mapper三、XML四、详解总结前言MyBATis的xml文件编写动态SQL

解决mysql插入数据锁等待超时报错:Lock wait timeout exceeded;try restarting transaction

《解决mysql插入数据锁等待超时报错:Lockwaittimeoutexceeded;tryrestartingtransaction》:本文主要介绍解决mysql插入数据锁等待超时报... 目录报错信息解决办法1、数据库中执行如下sql2、再到 INNODB_TRX 事务表中查看总结报错信息Lock

MySQL启动报错:InnoDB表空间丢失问题及解决方法

《MySQL启动报错:InnoDB表空间丢失问题及解决方法》在启动MySQL时,遇到了InnoDB:Tablespace5975wasnotfound,该错误表明MySQL在启动过程中无法找到指定的s... 目录mysql 启动报错:InnoDB 表空间丢失问题及解决方法错误分析解决方案1. 启用 inno

MySQL 安装配置超完整教程

《MySQL安装配置超完整教程》MySQL是一款广泛使用的开源关系型数据库管理系统(RDBMS),由瑞典MySQLAB公司开发,目前属于Oracle公司旗下产品,:本文主要介绍MySQL安装配置... 目录一、mysql 简介二、下载 MySQL三、安装 MySQL四、配置环境变量五、配置 MySQL5.1