ecshop是一款B2C独立网店系统,适合企业及个人快速构建个性化网上商店。系统是基于PHP语言及MYSQL数据库构架开发的跨平台开源程序。最新版本为3.6.0。而最近ecshop爆出存在SQL注入漏洞,且能影响至所有系列。本文就对该SQL注入漏洞的成因做简单的分析。
本次漏洞主要是由于user.php文件login响应存在漏洞,其内部的display的参数可被攻击者控制,从而导致SQL注入漏洞,利用该漏洞可实现远程任意命令执行。
login响应,将http_referer的值赋予$back_act,referer参数可被攻击者控制。
assign函数将$back_act变量值赋给back_act,smarty是模板引擎,将back_act的值赋给模板文件user_passport.dwt,display读取user_passport.dwt文件内容,过滤后输出结果。
display函数经 fetch -> make_compiled -> file_get_contents -> fetch_str ->smarty_prefilter_preCompile ->select 取出html中值$out,其中包含referer的内容。
$out通过_echash变量切割,而_echash是代码里写死的。
此时referer的payload被切割成$val。
insert_mod函数处理动态内容$val。
以|划分$val。
$para经unserialize反序列化得.
$fun($para)动态调用insert_ads函数,即insert_ads($para), insert_ads存在SQL注入漏洞,继续跟踪insert_ads,该函数直接将id,num的值拼接到SQL中导致注入漏洞。
其中id=”‘/*“ 拼接a.posttion_id的单引号,/*与num配合注释掉order by。
num中的*/与id/*配合注释order by ,union联合查询在数据库中解析得。
position_style经拼接重新到fetch。
fetch -> fetch_str 将匹配到的字符传输至select函数处理。
此时:
跟踪position_style至select函数。
select -> get_val –> make_var。
最终匹配得:
此时select中得:
并返回至fetch_str,供_eval调用,造成任意命令执行,本命令是通过base64解码写一句话木马。
针对3.x版本,ecshop添加了waf,过滤了union select,可以将这两个词放在id,num的值里绕过waf,同时修改_echash的值。
在虚拟机里安装ecshop2.7.3版本。
执行以上脚本,即可写入一句话木马<?php eval($_POST[1337]); ?> 至1.php,通过菜刀连接,拿到web服务器权限。
由于ecshop官方还未进行修复,可通过对insert_ads的num;id参数进行intval处理。
https://xz.aliyun.com/t/2689 https://blog.csdn.net/u012078682/article/details/37737015 http://ringk3y.com/2018/08/31/ecshop2-x%E4%BB%A3%E7%A0%81%E6%89%A7%E8%A1%8C/
精彩推荐
扫码关注腾讯云开发者
领取腾讯云代金券
Copyright © 2013 - 2025 Tencent Cloud. All Rights Reserved. 腾讯云 版权所有
深圳市腾讯计算机系统有限公司 ICP备案/许可证号:粤B2-20090059 深公网安备号 44030502008569
腾讯云计算(北京)有限责任公司 京ICP证150476号 | 京ICP备11018762号 | 京公网安备号11010802020287
Copyright © 2013 - 2025 Tencent Cloud.
All Rights Reserved. 腾讯云 版权所有