最近略微有点无聊,记事狗的东东还有以后我发文章的规范

2013-01-11 17:42:00 35 7474


今天下午突然觉得没神马好的资料学习了所以就略微说一下
php代码审计我知道很多人都在玩,所以写一个略微吐槽的东西
RIPS Notepad++ 插件 和 xdebug 还有那个Code V4 And more php黑盒
想必都是现在 进阶或入门阶段的主流工具
而现在直接利用的基本很少了 很多都是隐藏较深的二阶利用
表面上首先会用静态软件扫所有的代码 但是那些引擎非常有局限性 V4的还好但是免费版限制1w行代码 然后丢到黑盒里面去Fuzz  dbbug(bug库) 大量的去Fuzz POST GET HEAD 最后去看错误日志
上面的就是不那么重要的一个小过程时间大概10分钟配置就可以自己完成剩下过程
正式进入分析阶段了首先是funtion 文件结构 调用方式
Funton 我认为是分析阶段的基础 花点时间 然后回溯回去是十分有效的一种挖掘方式
一般比较短技巧就是可以用 V4
PHP中一般会减少变量的数量 但是传参过程难免出现问题但是从代码上并不能直观的发现所以需要配合xdebug
这时候 Notepad++ 插件 配合 xdebug 设置断点 观察变量具体出现了什么变化 然后依照这种变化回溯传递过程个个函数做了什么
之所以叫二阶 是因为 传入 储存 触发 输出 的过程中第一阶段无法达到目的但是在后面的阶段发生了问题程序员也未必能注意到 效率就是直观 和细致的了解
即使不debug 也可以使用变量输出函数。

然后是我以后规范 首先代码审计的研究学习过程也就是分析过程 我是不收费的不加密欢迎交流 但不会明确表示怎么利用 这部分转载 版权我打算给T00ls
我不在乎个人 我打算一一个群体的方式出现 比较php比较火了 也符合白帽子的规范
但是另外一部分 我觉得要有自己的灵魂 利用方面 为了不转载不扩散 同时实现自己自由的原则 加密+设置购买 可以也可以使用各种方式来取得exp
不知道t00ls怎么想毕竟我觉得还是需要大家的赞同

然后这里是例子 渣渣0day 原创的 不愿意看代码的直接翻到底部

记事狗 3.6.6 xss 0day
=======================================================
/modules/pm.mod.php
========================++2013/1/9/10:00++>
Funtion

filter()


function filter(&$string, $verify=1, $replace=1,$shield=0)  
{  
         static $filter = null;  
   
         $rets = array();  
   
                 $string=trim($string);  
         if($string) {  
                 if(false!==strpos($string,'<')) {  
                         $string=strip_selected_tags($string,"<script><iframe><style><link><meta>");  
                         $string=remove_xss($string);  
                 }  
   
                 if($filter===null) {  
                         $filter = (array) ConfigHandler::get('filter');  
                 }  
   
                 if(!$filter['enable']) {  
                         return false;  
                 }  
   
                                 if($replace && $filter['replace_list'])  
                 {  
                         foreach($filter['replace_list'] as $search=>$replace)  
                         {  
                                 $strpos = jstrpos($string, $search);  
   
                                 if($strpos!==false)  
                                 {  
                                         $string = str_replace($search, $replace, $string);  
                                 }  
                         }  
                 }  
   
                                 if(!empty($filter['keywords']))  
                 {  
                         if($filter['keyword_list']===null)  
                         {  
                                 $filter['keyword_list'] =  explode("|",str_replace(array("\r\n","\r","\n","\t","\\|"),"|",trim($filter['keywords'])));  
                         }  
   
                         foreach ($filter['keyword_list'] as $keyword)  
                         {  
                                 $strpos = jstrpos($string, $keyword);  
   
                                 if($strpos!==false)  
                                 {  
                                         $rets['error'] = 1;  
                                         $rets['type'] = 'filter';  
                                         $rets['keyword'] = $keyword;  
                                         $rets['msg'] = .($filter['keyword_disable'] ? "" : " {$keyword} ").;  
   
                                         return $rets;  
                                 }  
                         }  
                 }  
   
                                 if($verify && $filter['verify_list'])  
                 {  
                         foreach($filter['verify_list'] as $keyword)  
                         {  
                                 $strpos = jstrpos($string, $keyword);  
   
                                 if($strpos!==false)  
                                 {  
                                         $rets['verify'] = 1;  
                                         $rets['type'] = 'verify';  
                                         $rets['keyword'] = $keyword;  
                                         $rets['msg'] = .($filter['keyword_disable'] ? "" : " {$keyword} ")..MEMBER_ID.;  
   
                                         return $rets;  
                                 }  
                         }  
                 }  
   
                 if($shield && $shield!=0 && $filter['shield_list']){  
                         foreach($filter['shield_list'] as $keyword)  
                         {  
                                 $strpos = jstrpos($string, $keyword);  
   
                                 if($strpos!==false)  
                                 {  
                                         $rets['shield'] = 1;  
                                         $rets['type'] = 'shield';  
                                         $rets['keyword'] = $keyword;  
                                         $rets['msg'] = .($filter['keyword_disable'] ? "" : " {$keyword} ");  
   
                                         return $rets;  
                                 }  
                         }  
                 }  
         }  
   
         return false;  
}  
==================================
function sendAgain(){
                $pmid = (int) $this->Get['pmid'];
                $pm_list = array();
                $query = $this->DatabaseHandler->Query("select * FROM ".TABLE_PREFIX."pms WHERE pmid = '$pmid'");
                $pm_list = $query->GetRow();
                if($pm_list){
                        $this->DatabaseHandler->Query("delete from ".TABLE_PREFIX."pms where pmid = '$pmid' ");
                        $this->Post['to_user'] = $pm_list['tonickname'];
                        $this->Post['message'] = $pm_list['message'];
                       
                        $this->DoSend('outbox');
                }else{
                        $this->Messager("私信不存在或已删除");
                }
        }
==============================================
   
F:\PHPnow-1.5.6\htdocs\jsg\include\logic
======================================
function pmSend($post,$suid=MEMBER_ID,$susername=MEMBER_NAME,$snickname=MEMBER_NICKNAME){  
                 if($suid == MEMBER_ID) {  
                                                 $MemberHandler = & Obj::registry('MemberHandler');  
                         if($MemberHandler && $MemberHandler->HasPermission('pm','send')==false) {  
                                 return 6;  
                         }  
                 }  
                  
                 $this->noticeConfig = ConfigHandler::get('email_notice');  
                 $to_user_list=array();  
                 $f_rets = filter($post['message']);  
                 if($f_rets)  
                 {  
                         if($f_rets['error'])  
                         {  
                                 return $f_rets['msg'];  
                         }  
                 }  
                 $post['subject']=htmlspecialchars(trim($post['subject']));  
                 if($post['message']=='')  
                 {  
                         return 1;  
                 }  
                 if ($post['buddy_list']==false && $post['to_user']=="")  
                 {  
                         return 2;  
                 }  
   
                 if(trim($post['to_user'])!='')  
                 {  
   
                         $in=$this->DatabaseHandler->BuildIn($post['to_user'],"nickname");  
                                                 $sql="
                         SELECT  
                                 uid,username,nickname,notice_pm,email,newpm  
                         FROM  
                                 ".TABLE_PREFIX.'members'."  
                         WHERE  
                                 $in";
                         $query = $this->DatabaseHandler->Query($sql);  
   
                         while($row=$query->GetRow())  
                         {  
                                                                 if($suid == MEMBER_ID){  
                                         if(is_blacklist($suid,$row['uid'])){  
                                                 return .$row['nickname'].;  
                                         }  
                                 }  
                                                                 $rets = jsg_role_check_allow('sendpm', $row['uid'], $suid);  
                                 if($rets && $rets['error']) {  
                                         return $rets['error'];  
                                 } else {  
                                         $to_user_list[$row['uid']]=$row;  
                                 }  
                         }  
                 }  
                 $to_user_list+=(array)$post['buddy_list'];  
                 if($to_user_list==false)  
                 {  
                         return 3;  
                 }  
                                   
                 $time = time();  
                 $post['message'] = strstr($post['message'],"\\") ? $post['message'] : addslashes($post['message']);  
                                 foreach($to_user_list as $to_user_id => $to_user_name)  
                 {  
                         $data=array(  
                         "msgfrom"         =>$susername,  
                         "msgnickname"=>$snickname,  
                         "msgfromid"  =>$suid,                                                                  "msgto" => $to_user_name['username'],                                        "tonickname" => $to_user_name['nickname'],                                "msgtoid"   => $to_user_id,                                                                "subject"   => $post['subject'],  
                         "message"   => $post['message'],  
                         "new"=>'1',  
                         "dateline"=>$time,  
                         );  
   
                         if($post["save_to_outbox"])  
                         {  
                                 $data['folder']="outbox";  
                                 $msg=;  
                         }  
                                                 $uids = '';  
                         if($suid > $to_user_id){  
                                 $uids = $to_user_id.",".$suid;  
                         }else{  
                                 $uids = $suid.",".$to_user_id;  
                         }  
   
                         $plid = 0;  
                                                                         if(!$msg){  
                                                                 $lastmessage = addslashes(serialize($data));  
                                 $plid = $this->DatabaseHandler->ResultFirst("select plid from ".TABLE_PREFIX."pms_index where uids = '$uids'");  
   
                                 if($plid == 0){  
                                                                                 $this->DatabaseHandler->Query("insert into ".TABLE_PREFIX."pms_index (uids) values('$uids')");  
                                         $plid = $this->DatabaseHandler->Insert_ID();  
                                         if(0 != $plid){  
                                                                                                 $this->DatabaseHandler->Query("insert into ".TABLE_PREFIX."pms_list (plid,uid,pmnum,dateline,lastmessage) values('$plid','".$suid."',1,'$time','$lastmessage')");  
                                                 if($suid != $to_user_id){  
                                                         $this->DatabaseHandler->Query("insert into ".TABLE_PREFIX."pms_list (plid,uid,pmnum,dateline,lastmessage,is_new) values('$plid','$to_user_id',1,'$time','$lastmessage',1)");  
                                                 }  
                                         }  
                                 }else{  
                                                                                 $this->DatabaseHandler->Query("update ".TABLE_PREFIX."pms_list set pmnum = pmnum + 1,dateline = '$time',lastmessage = '$lastmessage',is_new = 1 where plid = '$plid' and uid = '$to_user_id' ");  
                                         if($suid != $to_user_id){  
                                                 $this->DatabaseHandler->Query("update ".TABLE_PREFIX."pms_list set pmnum = pmnum + 1,dateline = '$time',lastmessage = '$lastmessage',is_new = 0 where plid = '$plid' and uid = '$suid' ");  
                                         }  
                                 }  
                         }  
   
                         $data['plid'] = $plid;  
   
                         DB::insert('pms',$data);  
                                         }  
   
                 if($msg){  
                         return 4;  
                 }  
   
                 $num=$post["save_to_outbox"]?0:1;  
                 if($num > 0){  
                                                 $_tmps=array_keys($to_user_list);  
                         $to_user_id_list = array();  
                         foreach($_tmps as $_tmp) {  
                                 $_tmp = (int) $_tmp;  
                                 if($_tmp > 0) {  
                                         $to_user_id_list[$_tmp] = $_tmp;  
                                 }  
                         }  
========================================================
代码其实无需看
思路过程是Funtion 里
(这这句<$string=strip_selected_tags($string,"<script><iframe><style><link><meta>");  >)这里已经发现问题标签过滤不完整
>查找调用文件 回溯到短消息发送文件($f_rets = filter($post['message']);)虽然知道这里是浮云 $num=$post["save_to_outbox"]
> 查看上下 sendAgain() $this->Post['message'] = $pm_list['message']; 无过滤
一个是直接过滤入库 另外一个是直接入库
========================================================
EXP链接:https://www.t00ls.com/thread-21639-1-1.html
========================================================

休息一段时间看看是否有愿意一起来的朋友

看情况在放等 也许其他人会放出 版本太新用的人价值不高呵呵
不代表任何组织个人 只是在t00ls这个平台交流的一个小群体
我的思想就是 开放+利用 既有你想研究的 也有你想做的 这就是自由的灵魂无论善恶exp都有它纯在的意义 我认为的灰色和低调

关于作者

anlfi55篇文章3417篇回复

评论35次

要评论?请先  登录  或  注册