php木馬後門研究
七字铺
七字铺 2021-03-26 09:34:51
0
3
912

本人是學習不足,拿到一個源碼,但是發現有webshell後門,至於是哪些代碼,辨別不出來,煩請哪位大神指點一下。

       0 && @$val['ifshownav'])) { $newchannel[]=$val; $計數; } 如果($count==$num){ 返回 $newchannel; } } 返回 $newchannel; } } foreach($channel as $val){ if($fid==$val['fid']) { if($shownav==0 || ($shownav>0 && $val['ifshownav'])) { 如果($kind==0){ $newchannel[]=$val; $計數; $newchannel[count($newchannel)-1]['key']=$count; }elseif($val['ckind']==$kind) { $newchannel[]=$val; $計數; $newchannel[count($newchannel)-1]['key']=$count; } } } 如果($count==$num){ 休息; } } $fidarray=@cnav(cid,1); foreach($newchannel as $key=>$val){ $newchannel[$key]['onstyle']=''; foreach($fidarray as $fidkey=>$fidval){ if($val['cid']==$fidval['cid']) { $newchannel[$key]['onstyle']='on'; 休息; } } } 返回 $newchannel; } 函數 b($cid='',$return=false,$linktag=' > ',$homepage=SystemDir) { 返回 cnav($cid,$return,$linktag,$homepage); } 函數 i($kind='',$cid=0){ 如果($cid===0){ if(!define('cid')) {回傳 false;} $cid=cid; } $channel=getchannelcache($cid); if(!$channel) { 返回 false; } 如果(空($kind)){ 返回$頻道; }elseif($kind=='name' && isset($channel['cname'])) { 返回 $channel['cname']; }elseif($kind=='topfid') { $breadcrumb=b($channel['cid'],1); if(isset($breadcrumb[0]['cid'])) { 返回$breadcrumb[0]['cid']; } }elseif($kind=='url') { 返回 u($channel['cid']); }elseif($kind=='域') { 返回 @$channel['csetting']['channel_domain']; }別的 { if(isset($channel[$kind])) { 返回 $channel[$kind]; } } 返回 false; } 函數 uri($uri){ $uri=ltrim($uri,'/'); 如果(網址重寫){ 返回 SystemDir.$uri; }別的 { 返回 SystemDir.IndexFile.'/'.$uri; } } 函數 f($file){ 需要(SystemRoot.TemplateDir.DIRECTORY_SEPARATOR.$file); } 函數t($file='',$echo=1){ 如果($echo==1){ echo(SystemDir.TemplateDir.'/'.$file); } 返回 SystemDir.TemplateDir.'/'.$file; } 函數列表($where=''){ if(isset($where['page']) && !is_numeric($where['page'])) { if(isset($_GET[$where['page']]) && $_GET[$where['page']]>0) { $where['page']=intval($_GET[$where['page']]); }別的 { $where['page']=1; } } $nullarticle=array('list'=>array(),'pagecount'=>0,'pagesize'=>1,'page'=>1,); if(!isset($where['cid']) && !define('cid') && !isset($where['tablename']) && !isset($where['cids'])))(Return && !isset($where['cids'])) ;} if(!isset($where['tablename']) && !isset($where['cid']) && !isset($where['cids']) && define('cid')) {$where[' cid']=cid;} if(!isset($where['cid'])) {$where['cid']=0;} if(is_numeric($where['cid'])) {$where['cid']=intval($where['cid']);} if(SiteCache && isset($where['cache']) && $where['cache']>0) { $快取位置=$位置; $cachehash=md5(json_encode($where)); $res =cacheget($cachehash,$where['cache'],'alist'); if ($res) {return json_decode($res,1);} } $sql=''; if($where['cid']!==0) { $thischannelcache=getchannelcache($where['cid']); if(!$thischannelcache) {Return $nullarticle;} $where['cid']=$thischannelcache['cid']; } if(!isset($where['tablename'])) {$where['tablename']='';} if(!isset($where['all']) || $where['all']==1) { if(!isset($where['cids'])) {$where['cids']='';} $clistsetting=alist_getson($where['cid'],$where['tablename'],$where['cids']); if(!isset($clistsetting['sql'])) {Return $nullarticle;}$where['cidsql']=$clistsetting['sql']; $where['tablename']=$clistsetting['tablename']; $defaultsetting=getchannelcache($clistsetting['default']); if(!isset($where['pageurl']) && !isset($clistsetting['pageurl'])) { 取消設定($defaultsetting['csetting']['channel_pageurl']); } }別的 { if(!isset($where['cidsql'])) { $where['cidsql']=" 和 (cid='".$where['cid']."')"; } if($where['cid']) { $defaultsetting=getchannelcache($where['cid']); if(empty($where['tablename']) && isset($defaultsetting['csetting']['articletable'])) { $where['tablename']=$defaultsetting['csetting']['articletable']; } } } $sql.=$where['cidsql']; if(!isset($where['pagesize'])) { if(isset($defaultsetting['csetting']['temppage_size']) && !empty($defaultsetting['csetting']['temppage_size'])) { $where['pagesize']=$defaultsetting['csetting']['temppage_size']; } } if(!isset($where['order'])) { if(isset($defaultsetting['csetting']['temppage_order']) && !empty($defaultsetting['csetting']['temppage_order'])) { $where['order']=$defaultsetting['csetting']['temppage_order']; } } isset($where['addslashes']) ? $ifaddslashes=$where['addslashes']:$ifaddslashes=1; isset($where['表名']) ? $where['tablename']=$where['tablename']:die('no tablename'); isset($where['pagesize']) ? $where['pagesize']=intval($where['pagesize']):$where['pagesize']=9; isset($where['order']) ? $where['order']='order by '.$where['order']:$where['order']='order by id desc'; isset($where['start']) ? $where['start']=intval($where['start']):$where['start']=0; isset($where['column']) ? $where['column']=$where['column']:$where['column']='*'; isset($where['rowidstyle']) && !isset($where['rowidname'])? $where['rowidname']='id' :''; isset($where['linktime']) ? 1==1 : $where['linktime']='posttime'; isset($where['link']) ? 1==1 : $where['link']=''; isset($where['domain']) ? 1==1 : $where['domain']=''; if(trim($where['column'])<>'*') {$where['column'].=',cid';}if(isset($where['where'])) { if(is_array($where['where'])) { foreach($where['where'] as $key=>$val) { $key=addslashes_str($key,$ifaddslashes); if(is_array($val) && count($val)>0) { $sql.=" 和 ("; foreach($val 作為 $value){ $sql.=$key."='".addslashes_str($value,$ifaddslashes)."' 或"; } $sql=substr($sql,0,strlen($sql)-4); $sql.=")"; }別的 { $sql.=" 和 ".$key."='".addslashes_str($val,$ifaddslashes)."'"; } } }別的 { $sql.=" 和 ".$where['where']; } } if(isset($where['inwhere'])) { foreach($where['inwhere'] as $key=>$val) { if(!is_array($val)) { $val=數組(); $val[]=$where['inwhere'][$key]; } $key=addslashes_str($key,$ifaddslashes); foreach($val as $val1){ if(is_numeric($val1) && $val1>0) { $sql.=" 和(".$key."='[".$val1."]' 或".$key." 像'%,".$val1.",%' 或".$key. " "像'[".$val1.",%'或".$key."像'%,".$val1."]')"; }別的 { 取消設定($where['inwhere'][$key]); } } } } if(isset($where['無處'])) { foreach($where['nowhere'] as $key=>$val) { $key=addslashes_str($key,$ifaddslashes); if(is_array($val) && count($val)>0) { foreach($val 作為 $value){ $sql.=" 和 ".$key."<>'".addslashes_str($value,$ifaddslashes).'\''; } }別的 { $sql.=" 和 ".$key."<>'".addslashes_str($val,$ifaddslashes)."'"; } } } if(isset($where['other']) && !empty($where['other'])) { $sql.=" 和 ".$where['other']; } if(isset($where['keyword']) && !empty($where['keyword'])) { if(!isset($where['searchcolumn'])) {$where['searchcolumn']='title';} if(!is_array($where['searchcolumn'])) {$where['searchcolumn']=explode(',',$where['searchcolumn']);} if(!is_array($where['keyword'])) {$where['keyword']=explode('|',$where['keyword']);} $sql.=" 和 ("; foreach($where['searchcolumn'] as $key=>$searchcolumn) { foreach($where['keyword'] as $keywordkey=>$keywordval) { if($key==0&&$keywordkey==0){ $sql.="$searchcolumn 就像'%".addslashes_str($keywordval,$ifaddslashes)."%'"; }別的 { $sql.=" 或 $searchcolumn like '%".addslashes_str($keywordval,$ifaddslashes)."%'"; } } } $sql.=" )"; } if(!empty($sql)) { $sql='where'.ltrim($sql,'and'); } if(isset($where['page'])) { $where['page']=intval($where['page']); $where['pagecount'] = $GLOBALS['db'] -> fetchcount("SELECT count(id) FROM".$where['tablename']."$sql"); $where['articlecount']=$where['pagecount']; $where['start']=($where['page']-1)*$where['pagesize']; if($where['articlecount']%$where['pagesize']==0) { $where['pages']=($where['articlecount']/$where['pagesize']); }別的 { $where['pages']=intval($where['articlecount']/$where['pagesize']) 1; } if(isset($defaultsetting['csetting']['channel_pageurl']) && !empty($defaultsetting['csetting']['channel_pageurl']) && !isset($where['pageurl'])) { $allpageurl=explode(';',$defaultsetting['csetting']['channel_pageurl']); 如果(網址重寫){ $where['pageurl']=$allpageurl[0]; }別的 { $where['pageurl']=SystemDir.IndexFile.$allpageurl[0]; } } } if(!isset($where['sql'])) { $where['sql_id']='SELECT id FROM'.$where['tablename'].' '.$sql。' '.$where['order'].'限制'.$where['start'].','.$where['pagesize']; $idquery=$GLOBALS['db'] ->查詢($where['sql_id']); $ids=$GLOBALS['db']-> fetchall($idquery); $sql='id in('; if(count($ids)>0) { foreach($ids as $key=>$val){ $sql.=$val[0].','; } }別的 { $sql.='0,'; } $sql=rtrim($sql,','); $sql.=')'; $where['sql']='SELECT '.$where['column'].' FROM '.$where['表名'].'其中“.$sql”。 '.$where['訂單']; } $query = $GLOBALS['db'] ->;查詢($where['sql']); $articles = $GLOBALS['db'] ->; fetchall($查詢); $i=0; foreach($文章為$值) { $i ; $value['key']=$i; if(isset($where['stepstyle'])) { foreach($where['stepstyle'] as $key=>$val) {if($i%$key==0) {$value['stepstyle']=$where['stepstyle'][$key] ; }} if(!isset($value['stepstyle'])) {$value['stepstyle']='';} }if(isset($where['rowstyle'])) { foreach($where['rowstyle'] as $key=>$val) {if($i==$key) {$value['rowstyle']=$where['rowstyle'][$key];} } if(!isset($value['rowstyle'])) {$value['rowstyle']='';} } if(isset($where['rowidstyle'])) { foreach($where['rowidstyle'] as $key=>$val) { if($value[$where['rowidname']]==$key) { $value['rowidstyle']=$val; } } if(!isset($value['rowidstyle'])) {$value['rowidstyle']='';} } if(!isset($value[$where['linktime']])) {$value[$where['linktime']]=0;} $value['link']=aurl($value,$where['link'],$value[$where['linktime']],$where['domain']); $where['list'][]=$value; } if(!isset($where['list'])) {$where['list']=array();} if(SiteCache && isset($where['cache']) && $where['cache']>0) { 快取集($cachehash,json_encode($where),$where['cache'],'alist'); } 返回 $where; } 函數 getkinds($cid,$fid) { $fid=intval($fid); $kindsarray=數組($fid); 如果(is_numeric($cid)){ $thichannelcache=getchannelcache($cid); $defaultsetting=$thichannelcache['csetting']; if(isset($defaultsetting['articletable']) &&!empty($defaultsetting['articletable'])) { $kindtable=$defaultsetting['articletable']; }其他{返回$kindsarray;} }別的 { $kindtable=$cid; } $query = $GLOBALS['db'] ->;查詢(“從$ kindtable中選擇id,其中fid ='$ fid';”); $link = $GLOBALS['db'] -> fetchall($查詢); foreach($link 作為$value) { $thisallkinds=getkinds($kindtable,$value['id']); foreach($thisallkinds 作為 $thisvalue) { $kindsarray[]=$thisvalue; } } 返回$kindsarray; } 函數 alist_getson($cid,$tablename,$cids,$first=1) { if($cid==0 && 空($tablename)) { $表名=文章表; } $數組=數組(); $array['list']=array(); $channels=getchannelscache(); 如果($第一個){ if(!is_array($cids)) {$cids=explode(';',$cids);} $thischannel=getchannelcache($cid); if($thischannel && @$thischannel['ckind']==2 && (in_array($cid,$cids) || 空($cids[0]))) { if(isset($thischannel['csetting']['articletable']) && !empty($thischannel['csetting']['articletable']) && empty($tablename)) { $tablename=$thischannel['csetting']['articletable']; }if($tablename==$thischannel['csetting']['articletable']) { $array['list'][]=$thischannel; if(isset($thischannel['csetting']['channel_pageurl']) && !empty($thischannel['csetting']['channel_pageurl'])) { $array['pageurl']=$thischannel['csetting']['channel_pageurl']; } } } $array['表名']=$表名; } foreach($channels as $key=>$val) { if($val['fid']==$cid) { $thischannel=getchannelcache($val['cid']); 如果(空($表名)){ if($thischannel['ckind']==2 && isset($thischannel['csetting']['articletable']) && (in_array($val['cid'],$cids) || 空($cids[ 0]))) { $array['list'][]=$val; $tablename=$thischannel['csetting']['articletable']; $array['表名']=$表名; } }別的 { if($thischannel['ckind']==2 && isset($thischannel['csetting']['articletable']) && $thischannel['csetting']['articletable']==$tablename && (in_array( (in_array()$ val['cid'],$cids) || 空($cids[0]))) { $array['list'][]=$val; } } $sonarray=alist_getson($val['cid'],$tablename,$cids,0); foreach($sonarray['list'] as $key1=>$val1) { $array['list'][]=$val1; } } } 如果($第一個){ $cids=數組(); $sql=''; foreach($array['list'] as $key=>$val) { 如果($key==0){ $sql.=" 和 (cid='".$val['cid']."'"; }elseif($key==(count($array['list'])-1)) { $sql.=" 或 cid='".$val['cid']."'"; }別的 { $sql.=" 或 cid='".$val['cid']."'"; } } if(count($array['list'])>0) {$array['sql']=$sql.')';} if(isset($array['list'][0])) { $array['default']=$array['list'][0]['cid']; }別的 { $數組['預設']=0; } 返回$數組; }別的 { 返回$數組; } } 函數aurl($value,$rowurl,$rowurltime,$domain=''){ $thissetting=getchannelcache($value['cid']); 如果(空($網域)){ if(isset($thissetting['csetting']['channel_domain']) && !empty($thissetting['csetting']['channel_domain'])) { $domains=explode(';',$thissetting['csetting']['channel_domain']); $域名=$域名[0]; foreach($domains 作為 $key){ if($key==server_name()) { $域=空; 休息; } } } } 如果(空($rowurl)){ if(空($thissetting['csetting']['channel_articleurl'])) { 返回 ''; } $rowurl=$thissetting['csetting']['channel_articleurl']; }if(!empty($where['domain'])) { $domains=explode(';',$where['domain']); $where['domain']=$domains[0]; foreach($domains 作為 $domain){ if($domain==server_name()) { $where['domain']=null; 休息; } } } 取消設定($這個設定); $rowurls=explode(';',$rowurl); $rowurl=$rowurls[0]; preg_match_all("/{(.*)}|\[(.*)\]|\((.*)\)/isU",$rowurl,$match); if(count($match[0])>0) { foreach($match[0] as $key=>$val) { if($rowurltime>0 && ($val=='(y)' || $val=='(m)' || $val=='(d)')) { isset($value['y']) ? 1==1 : $value['y']=date('Y',$rowurltime); isset($value['m']) ? 1==1 : $value['m']=date('m',$rowurltime); isset($value['d']) ? 1==1 : $value['d']=date('d',$rowurltime); } if(isset($value[$match[1][$key]])) { if(is_numeric($value[$match[1][$key]])) {$rowurl=str_replace($val,$value[$match[1][$key]],$rowurl);}else {$ rowurl=str_replace($val,urlencode($value[$match[1][$key]]),$rowurl);} } if(isset($value[$match[2][$key]])) { if(is_numeric($value[$match[2][$key]])) {$rowurl=str_replace($val,$value[$match[2][$key]],$rowurl); }其他{$rowurl=str_replace($val,urlencode($value[$match[2][$key]]),$rowurl); } } if(isset($value[$match[3][$key]])) { if(is_numeric($value[$match[3][$key]])) {$rowurl=str_replace($val,$value[$match[3][$key]],$rowurl); }其他{$rowurl=str_replace($val,urlencode($value[$match[3][$key]]),$rowurl); } } } } if(!empty($domain)) { $domain='//'.$domain.server_port(); } 如果(網址重寫){ $rowurl=$domain.$rowurl; }別的 { $rowurl=$domain.SystemDir.IndexFile.$rowurl; } 返回$rowurl; } 函數 all_list($where=array(),$pagesize=10,$cid='') { if(!isset($where['cache'])) {$where['cache']=3600;} $cachehash=md5(json_encode($where).$pagesize.json_encode($cid)); $res =cacheget($cachehash,$where['cache'],'alist'); if ($res) {return json_decode($res,1);} 如果(空($cid)){ $cid=數組(); $allchannels=getchannelscache(); foreach($allchannels as $channel){ if($channel['ckin']==2) { $cid[]=$channel['cid']; } } }elseif(is_numeric($cid)) { $cid=數組($cid); } $文章=陣列(); foreach($cid as $thiscid) { $where['cid']=$thiscid; $where['pagesize']=$pagesize; $where['all']=0; $thisarticles=alist($where); foreach($thisarticles['list'] as $thisarticle) { $文章[]=$這篇文章; } } $posttime=陣列(); foreach($articles as $article){ $posttime[] = $article['posttime']; }$orderarticles=array_multisort($posttime, SORT_DESC, $articles); $returnarticles=陣列(); $i=0; foreach($articles as $key=>$val) { $i ; $val['key']=$i; $returnarticles[]=$val; if($key==($pagesize-1)) { 休息; } } if(SiteCache && $where['cache']>0) { 快取集($cachehash,json_encode($returnarticles),$where['cache'],'alist'); } 返回$returnarticles; } 函數 ainsert($article,$setting='') { if(!is_array($article)) {回傳 false;} if(空($setting)) {$setting=array();} if(!isset($setting['cid']) && !isset($article['cid'])) { 如果(已定義('cid')){ $setting['cid']=cid; }別的 { return '設定無 cid'; } } if(!isset($setting['addslashes'])) {$setting['addslashes']=1;} if(!isset($setting['default'])) {$setting['default']=1;} if(!isset($setting['check'])) {$setting['check']=1;} if(!isset($setting['cid'])) {$setting['cid']=$article['cid'];} if(isset($article['cid'])) {unset($article['cid']);} $channel = getchannelcache($setting['cid']); if(!$channel) {Return '頻道不存在';} $setting['cid']=$channel['cid']; $csetting=$channel['csetting']; if(!isset($setting['tablename']) || empty($setting['tablename'])) {$setting['tablename']=$csetting['articletable'];} if(count($article)==0) { return 'where 文章列'; } foreach($article as $key=>$val){ $article[$key]=addslashes_str($article[$key],$setting['addslashes']); } if($setting['檢查']) { $columns=$GLOBALS['db']-> all("select mname,mkind,ifonly,strdefault,msetting from".tableex('moudle')." where cid=".$setting['cid']." order by morder asc;"); foreach($columns as $thiscolumn){ $key=$thiscolumn['mname']; if(!isset($article[$key]) && $setting['default']) { $article[$key]=$thiscolumn['strdefault']; if($thiscolumn['mkind']==9) { if($thiscolumn['strdefault']=='now') { $文章[$key]=時間(); }別的{ $thiscolumn['strdefault']=@strtotime($thiscolumn['strdefault']); if($thiscolumn['strdefault']) { $article[$key]=$thiscolumn['strdefault']; }別的 { $文章[$鍵]=0; } } } }if(isset($article[$key])) { $thismsetting=json_decode($thiscolumn['msetting'],1); $thismsetting['ifonly']=$thiscolumn['ifonly']; $thismsetting['表名']=$setting['表名']; $thismoudlevalue=$article[$key]; if($thismsetting['filterhtml']==1) { require_once(SystemRoot.AdminDir.'/input/kses.php'); $thisismoudlevalue= kses($thisismoudlevalue); }elseif($thismsetting['filterhtml']==2) { $thisismoudlevalue=htmlspecialchars($thisismoudlevalue); } $acheck=acheck($key,$thisismoudlevalue,$setting['cid'],$thismsetting); if($acheck==='error') {返回$key。'錯誤';} if($acheck==='short') {返回 $key。'短的';} if($acheck==='long') {返回 $key。'長的';} if($acheck==='exist') {返回$key。'存在';} $article[$key]=$thismoudlevalue; } } } $article['cid']=$setting['cid']; if(!isset($article['posttime'])) {$article['posttime']=time();} if(!isset($article['adminuid'])) {$article['adminuid']=0;} $結果 = $GLOBALS['db'] ->插入($setting['表名'],$article); if($result) {回傳 $result;}else {回傳 false;} } 函數 aedit($article,$setting='') { if(!isset($article['id']) || !is_numeric($article['id']) || $article['id']<1) { 返回“id 錯誤”; } $id=$article['id']; 取消設定($article['id']); if(!is_array($article)) {回傳 false;} if(空($setting)) {$setting=array();} if(!isset($setting['cid']) && !isset($article['cid'])) { 如果(已定義('cid')){ $setting['cid']=cid; }別的 { return '設定無 cid'; } } if(!isset($setting['addslashes'])) {$setting['addslashes']=1;} if(!isset($setting['check'])) {$setting['check']=1;} if(!isset($setting['cid'])) {$setting['cid']=$article['cid'];} if(isset($article['cid'])) {unset($article['cid']);} $channel = getchannelcache($setting['cid']); if(!$channel) {Return '頻道不存在';} $setting['cid']=$channel['cid']; $csetting=$channel['csetting']; if(!isset($setting['tablename']) || empty($setting['tablename'])) {$setting['tablename']=$csetting['articletable'];} if(count($article)==0) { return 'where 文章列'; } foreach($article as $key=>$val){ $article[$key]=addslashes_str($article[$key],$setting['addslashes']); }if($setting['檢查']) { $columns=$GLOBALS['db']-> all("select mname,ifonly,strdefault,msetting from".tableex('moudle')." where cid=".$setting['cid']." order by morder asc;"); foreach($columns as $thiscolumn){ $key=$thiscolumn['mname']; if(isset($article[$key])) { $thismsetting=json_decode($thiscolumn['msetting'],1); $thismsetting['ifonly']=$thiscolumn['ifonly']; $thismsetting['表名']=$setting['表名']; $thismoudlevalue=$article[$key]; if($thismsetting['filterhtml']==1) { require_once(SystemRoot.AdminDir.'/input/kses.php'); $thisismoudlevalue= kses($thisismoudlevalue); }elseif($thismsetting['filterhtml']==2) { $thisismoudlevalue=htmlspecialchars($thisismoudlevalue); } $acheck=acheck($key,$thisismoudlevalue,$setting['cid'],$thismsetting,$id); if($acheck==='error') {返回$key。'錯誤';} if($acheck==='short') {返回 $key。'短的';} if($acheck==='long') {返回 $key。'長的';} if($acheck==='exist') {返回$key。'存在';} $article[$key]=$thismoudlevalue; } } } $結果 = $GLOBALS['db'] -> update($setting['tablename'],"id='$id'",$article); if($result) {回傳 true;}else {回傳 false;} } 函數 adel($cid,$id,$tablename='') { if(空($cid) && 空($tablename)) { 如果(已定義('cid')){ $cid=cid; }別的 { 返回“無 cid”; } } if(empty($id)) {Return 'no id';}else {$id=intval($id);} 如果(空($表名)){ $channel = getchannelcache($cid); if(!$channel) {Return '頻道不存在';} $cid=$channel['cid']; $csetting=$channel['csetting']; $tablename=$csetting['articletable']; } $query = $GLOBALS['db'] ->;查詢(“從`$tablename`WHERE id='$id'刪除”); 如果($查詢){ 傳回 true; }別的 { 返回 false; } } 函數acheck($mname,$value,$cid='',$thismsetting='',$id=0){ 如果($cid==''){ 如果(已定義('cid')){ $cid=cid; }別的 { 返回“無 cid”; } }if($thismsetting=='') { $column = $GLOBALS['db'] ->; one("select mname,ifonly,msetting from".tableex('moudle')." where cid='".$cid."' and mname='".$mname."' limit 1;"); $thismsetting=json_decode($column['msetting'],1); $thismsetting['ifonly']=$column['ifonly']; } if(isset($thismsetting['regular']) && strlen($thismsetting['regular'])>3 && !empty($value)) { if(!preg_match($thismsetting['regular'],$value)){ 返回“錯誤”; } } if(isset($thismsetting['lenmin']) && is_numeric($thismsetting['lenmin']) && $thismsetting['lenmin']>0) { if(strlen($value)<$thismsetting['lenmin']) { 返回“短”; } } if(isset($thismsetting['lenmax']) && is_numeric($thismsetting['lenmax']) && $thismsetting['lenmax']>0) { if(strlen($value)>$thismsetting['lenmax']) { 返回“長”; } } if($thismsetting['ifonly']==1) { if(!isset($thismsetting['tablename'])) { $channel = getchannelcache($cid); $thismsetting['tablename']=$channel['csetting']['articletable']; } 如果($id>0){ $pagecount = $GLOBALS['db'] ->; fetchcount("SELECT id FROM".$thismsetting['tablename']." where $mname='$value' and cid='".$cid."' and id<>'$id' limit 1;") ; }別的 { $pagecount = $GLOBALS['db'] ->; fetchcount("SELECT id FROM".$thismsetting['tablename']." where $mname='$value' and cid='".$cid."' limit 1;"); } if($pagecount) { 返回「存在」; } } 傳回 true; } 函數addslashes_str($val,$addslashes){ 如果($addslashes){ 返回 dbstr($val); }別的 { 返回$val; } } 函數 pagelist($alist,$url='',$returnarray=0) { if(!isset($alist['pagecount']) || !isset($alist['page'])) { 返回 false; } $recordcount=$alist['pagecount']; $pagesize=$alist['pagesize']; $curpage=$alist['頁面']; $pages=isset($alist['showpages']) ? $alist['showpages'] :3 ; if(empty($url) && isset($alist['pageurl']) && !empty($alist['pageurl'])) { $url=$alist['pageurl']; if(isset($alist['cid'])) { $url=str_replace('(cid)',$alist['cid'],$url); } }別的 { 如果(網址重寫){ $url=$_SERVER['REQUEST_URI']; }別的 { $url=$_SERVER['SCRIPT_NAME'].$_SERVER['REQUEST_URI']; } } if(stripes($url,'page=')===false) { if(stripes($url,'?')===false) { $url=$url."?page=(頁)"; }別的 { $url=$url."&page=(頁)"; } } } } $url = preg_replace("/page=([0-9] )/is", "page=(page)", $url); } } if($pagesize<1) { $頁面大小=1; } } $pagearray=數組(); $totalpage = max(ceil($recordcount/$pagesize),1); if($curpage<0 || $curpage>$totalpage) $curpage=1; $outhtml = ""; $pageno = $curpage; if($page<0 || $page>$totalpage) $page=1; 如果($pageno==1){ $pagearray[]=array('url'=>str_replace('(page)','1',$url),'title'=>'<<','class'=>'已停用'); }別的 { $pagearray[]=array('url'=>str_replace('(page)','1',$url),'title'=>'<<','class'=>' ) ; } } if($pages>$totalpage){ $ 起始頁 = 1 ; $endpage=min($startpage $pages,$totalpage); }別的{ $startpage=max($totalpage-$pages,1); $startpage=min($startpage,$curpage); $endpage=min($startpage $pages,$totalpage); } } if($page>1){ $pagearray[]=array('url'=>str_replace('(page)',$pageno-1,$url),'title'=>'<','class'=>'') ; }別的{ $pagearray[]=array('url'=>str_replace('(page)',1,$url),'title'=>'<','class'=>'停用'); } } for($i=$startpage;$i<=$endpage;$i) { 如果($curpage==$i){ $pagearray[]=array('url'=>str_replace('(page)',$i,$url),'title'=>$i,'class'=>'on'); }別的{ $pagearray[]=array('url'=>str_replace('(page)',$i,$url),'title'=>$i,'class'=>''); } } } } if($pageno<$totalpage){ $pagearray[]=array('url'=>str_replace('(page)',$pageno1,$url),'title'=>'>','class'=>''); }別的{ $pagearray[]=array('url'=>str_replace('(page)',$totalpage,$url),'title'=>'>','class'=>'停用'); } } if($page==$totalpage) { $pagearray[]=array('url'=>str_replace('(page)',$totalpage,$url),'title'=>'>>','class'=>'停用' ); }別的 { $pagearray[]=array('url'=>str_replace('(page)',$totalpages,$url),'title'=>'>>','class'=>'') ; } } 如果($returnray){ 返回 $pagearray ; } }別的 { $outhtml=''; foreach($pagesarray as $val){ if(!empty($val['class'])) { $val['class']=' class="'.$val['class'].'"'; } $outhtml.='
       
        
         '.$val['title'] .'< /a>'; } } 迴聲 $outhtml; } 函數導航($where=0){ $通道數組=數組(); if(!is_array($where)) { $thiscid=$where; $where=數組(); $where['cid']=$thiscid; } if(!isset($where['cid'])) { $where['cid']=0; } $cid=$where['cid']; if(!isset($where['oncid'])) { 如果(已定義('cid')){ $where['oncid']=cid; }別的 { $where['oncid']=0; } // 取出所有的id } if(!isset($where['onstyle'])) { $where['onstyle']=' class="on"'; } if(!isset($where['bro'])) {$where['bro']=1;} if(!isset($where['papa'])) {$where['papa']=1;} if($where['cid']==0) { if(!isset($where['首頁'])) { $where['首頁']['名稱']='首頁'; $where['homepage']['url']=gethomeurl(); $where['主頁']['目標']=''; }別的 { if(is_array($where['首頁'])) { if(!isset($where['首頁']['名稱'])) { $where['首頁']['名稱']='首頁'; } if(!isset($where['首頁']['url'])) { $where['homepage']['url']=gethomeurl(); } if(!isset($where['首頁']['目標'])) { $where['主頁']['目標']=''; } } } if(is_array($where['首頁'])) { $channelarray[]=array('cid'=>'0','fid'=>'0','name'=>$where['主頁']['name'],'url'= >$where ['homepage']['url'],'target'=>$where['homepage']['target']); } } $allchannels=getchannelscache(); $通道=陣列(); foreach($allchannels as $val) { if($val['ifshownav']==1) { $channels[]=$val; } } $計數=0; $myfid=0; $付費=0; foreach($channels as $channel){ 如果(is_numeric($cid)){ if($channel['cid']==$cid) { $myfid=$channel['fid']; if($cid>0 && $where['papa']==1) { $channelarray['papa']=$myfid;//顯示父欄目 $papaid=$myfid; } } if($channel['fid']==$cid) { $計數=1; $channelarray[]=$channel; } }elseif(is_array($cid)) { if(in_array($channel['cid'],$cid)) { $計數=1; $channelarray[]=$channel; } } }if($count>0 && is_numeric($cid) && $cid>0 && $where['papa']==1) { $channelarray['papa']=$cid; } 如果($count==0){ $noonpapaid=$myfid; }別的 { $noonpapaid=假; } if(isset($channelarray['papa']) && $channelarray['papa']>0) { foreach($channels as $channel){ if($channel['cid']==$channelarray['papa']) { $channelarray['papa']=$channel; } } }別的 { 取消設定($channelarray['papa']); } if(isset($where['bro']) && $where['bro']==1 && $count==0 && is_numeric($cid)) { // 顯示兄弟欄目 if(isset($myfid) && $myfid>0) { foreach($channels as $key=>$channel){ if($channel['fid']==$myfid) {$channelarray[]=$channel;} } }elseif(isset($myfid) && $myfid==0) { foreach($channels as $key=>$channel){ if($channel['cid']==$cid) {$channelarray[]=$channel;} } } } $onarray=數組(); 如果(已定義('cid')){ $thiscid=cid; 而(1<2){ $ifin=假; foreach($channels as $channel){ if($channel['cid']==$thiscid && $channel['cid']!=$noonpapaid) { $onarray[]=$channel['cid']; $thiscid=$channel['fid']; $ifin=真; 休息; } } if($ifin===false || $thiscid==0) { 休息; } } } $returnarray=數組(); $returnstr=''; if(!isset($where['html'])) { $where['html']='{name}'; } if(isset($GLOBALS['nav'][$cid])) { if(is_array($GLOBALS['nav'][$cid])) { $channelarray=$GLOBALS['nav'][$cid]; }elseif(function_exists($GLOBALS['nav'][$cid])){ $channelarray=$GLOBALS['nav'][$cid]($cid); } } foreach($channelarray as $key=>$channel){ $thisstr=$where['html']; if(!isset($channel['onstyle']) || empty($channel['onstyle'])) { if(in_array($channel['cid'],$onarray)) { $channel['onstyle']=$where['onstyle']; }別的 { $channel['onstyle']=''; } } if(define('cid') && cid==0 && $channel['cid']==0) {//首頁 $channel['onstyle']=$where['onstyle']; } $returnarray[]=$頻道; if(!isset($where['returnarray']) || $where['returnarray']==0) { $thisstr=str_replace('{url}',@$channel['url'],$thisstr); $thisstr=str_replace('{target}',@$channel['target'],$thisstr); $thisstr=str_replace('{name}',@$channel['name'],$thisstr); $thisstr=str_replace('{onstyle}',@$channel['onstyle'],$thisstr); $returnstr.=$thisstr."\r\n"; } } if(!isset($where['returnarray']) || $where['returnarray']==0) { 返回 $returnstr; }別的{ 返回$returnarray; } } 函數 cnav($cid='',$returnarray=false,$linktag=' > ',$homepage=SystemDir) { 如果(空($cid)){ 如果(定義('cid')){ $cid=cid; }別的 { $cid=0; } } $channels=getchannelscache(); $麵包屑=''; $breadcrumbarray=陣列(); 而(1<2) { $這個頻道=假; foreach($channels as $channel){ if($channel['cid']==$cid) { $這個頻道=$頻道; } } if($thischannel==false) { if($breadcrumb=='') { $breadcrumb='
         
          首頁'; }別的 { $breadcrumb='
          首頁'.$linktag.$breadcrumb; } if($returnarray) { 返回 array_reverse($breadcrumbarray); }別的 { 返回$breadcrumb; } }別的 { if($breadcrumb=='') { $breadcrumb=''.$thischannel['name'].''; }別的 { $breadcrumb=''.$thischannel['name'].''.$linktag.$breadcrumb; } $breadcrumbarray[]=$這個頻道; $cid=$thischannel['fid']; } } } 函數 getallchannelscache() { if(isset($GLOBALS['allchannelscache'])) { 返回 $GLOBALS['allchannelscache']; } $channelcachekeyname='allchannelscache'; $channelcache=cacheget($channelcachekeyname,604800,'通道'); if($channelcache) { $channels=json_decode($channelcache,1); }別的 { $channelslist=$GLOBALS['db']->all("從 ".tableex('channel') 選擇 cid,fid,ifshownav,cname,ckind,cvalue,newwindow,csetting。" 其中 ckind<>'4 '按編碼升序排序"); if($channelslist) { $通道=陣列(); foreach($channelslist as $val){ 取消設定($這個頻道); $這個頻道=陣列(); $thischannel['cid']=$val['cid']; $thischannel['fid']=$val['fid']; $thischannel['ckind']=$val['ckind']; $thischannel['ifshownav']=$val['ifshownav']; $thischannel['name']=$val['cname']; if($val['newwindow']==1) { $thischannel['target']=' target="_blank" '; }別的 { $thischannel['目標']=''; } $thischannel['url']=getchannelurl($val); 如果(空($thischannel['url'])){ $thischannel['url']='#'; $thischannel['目標']=''; }$channels[]=$這個頻道; } 快取集($channelcachekeyname,json_encode($channels),604800,'channel'); }別的 { 返回數組(); } } $GLOBALS['allchannelscache']=$channels; 返回 $channels; } 函數 getchannelscache() { if(isset($GLOBALS['channelscache'])) { 返回 $GLOBALS['channelscache']; } $channelcachekeyname='channelscache'; $channelcache=cacheget($channelcachekeyname,604800,'通道'); if($channelcache) { $channels=json_decode($channelcache,1); }別的 { $channelslist=$GLOBALS['db']->all("從 ".tableex('channel') 選擇 cid,fid,ifshownav,cname,ckind,cvalue,newwindow,csetting。" 其中 ckind<>'4 '和ifshow=1 依編碼asc 排序"); if($channelslist) { $通道=陣列(); foreach($channelslist as $val){ 取消設定($這個頻道); $這個頻道=陣列(); $thischannel['cid']=$val['cid']; $thischannel['fid']=$val['fid']; $thischannel['ckind']=$val['ckind']; $thischannel['ifshownav']=$val['ifshownav']; $thischannel['name']=$val['cname']; if($val['newwindow']==1) { $thischannel['target']=' target="_blank" '; }別的 { $thischannel['目標']=''; } $thischannel['url']=getchannelurl($val); 如果(空($thischannel['url'])){ $thischannel['url']='#'; $thischannel['目標']=''; } $channels[]=$這個頻道; } 快取集($channelcachekeyname,json_encode($channels),604800,'channel'); }別的 { 返回數組(); } } $GLOBALS['channelscache']=$channels; 返回 $channels; } 函數 getchannelcache($cid){ if(isset($GLOBALS['channelcache'][$cid])) { 返回 $GLOBALS['channelcache'][$cid]; } $channelcachekeyname='channelcache_'.$cid; $channelcache=cacheget($channelcachekeyname,604800,'通道'); if($channelcache) { $channelcache=json_decode($channelcache,1); }別的 { 如果(is_numeric($cid)){ $channelcache=$GLOBALS['db']->one("SELECT * FROM".tableex('channel')." where cid='$cid' limit 1"); }別的 { $channelcache=$GLOBALS['db']->one("SELECT * FROM".tableex('channel')." where cname='$cid' limit 1"); } if($channelcache) { $channelcache['csetting']=json_decode($channelcache['csetting'],1); 快取集($channelcachekeyname,json_encode($channelcache),604800,'channel'); }別的 { 返回 false; } } $GLOBALS['channelcache'][$cid]=$channelcache; 返回$channelcache; }函數 getchannelurl($cid){ if(!is_array($cid)) { $cid=getchannelcache($cid); if(!$cid) {回傳 false;} $csetting=$cid['csetting']; }別的 { $csetting=json_decode($cid['csetting'],1); } $頻道=$cid; if($channel['ckind']==3 || $channel['ckind']==4 || $channel['ckind']==5) { 返回 $channel['cvalue']; }elseif($channel['ckind']==1 || $channel['ckind']==2) { if(isset($csetting['template']) && 空($csetting['template'])) { 返回 ''; } } if(!isset($csetting['channel_url'])) {Return '';} $channelurls=explode(';',$csetting['channel_url']); $channelurl=str_replace("(cid)",$cid['cid'],$channelurls[0]); 如果(空($channelurl)){ 返回 ''; } if(!isset($csetting['channel_domain']) || empty($csetting['channel_domain'])) { $csetting['channel_domain']=系統域; } if(isset($csetting['channel_domain']) && $csetting['channel_domain']<>'') { $channel_domains=explode(';',$csetting['channel_domain']); $csetting['channel_domain']=$channel_domains[0]; foreach($channel_domains 作為 $channel_domain){ if(stripos($channel_domain,'*')===false) { $csetting['channel_domain']=$channel_domain; 休息; } } foreach($channel_domains 作為 $channel_domain){ if(server_name()==$channel_domain) { $csetting['channel_domain']=''; 休息; } } } 如果(網址重寫){ if(空($csetting['channel_domain'])) { $thisurl=$channelurl; }別的 { $thisurl='//'.$csetting['channel_domain'].server_port().$channelurl; } }別的 { if(空($csetting['channel_domain'])) { $thisurl=SystemDir.IndexFile.$channelurl; }別的 { $thisurl='//'.$csetting['channel_domain'].server_port().SystemDir.IndexFile.$channelurl; } } 返回$thisurl; } 函數 gethomeurl(){ if(isset($GLOBALS['homeurl'])) { 返回 $GLOBALS['homeurl']; } if(!UrlRewrite) { $indexfile=索引檔; }別的 { $indexfile=''; } $domains=explode(';',SystemDomain); foreach($domains 作為 $domain){ $域=修剪($域); if($domain==server_name()) { $GLOBALS['homeurl']=SystemDir.$indexfile; 返回 $GLOBALS['homeurl']; } } if(SystemDomain=='') {$GLOBALS['homeurl']=SystemDir.$indexfile;Return&
         
        
       
七字铺
七字铺

全部回覆 (2)
欧阳

你這個文件,全部是方法,還必須用資料庫。這咋看?

那你只能一個方法一個方法的試。你導入資料庫,看看是不是有資料庫注入了。

  • 回覆 好的,我還是入門級別,多謝大神的指點。
    七字铺 作者 2021-03-28 14:20:30
七字铺

貼文無法重新編輯,由於程式碼太長,好像顯示不全,這裡用網盤傳文件了,

#下載:https://wwa.lanzous.com/iTtK9nbjdja 密碼:f2p0

    最新下載
    更多>
    網站特效
    網站源碼
    網站素材
    前端模板
    關於我們 免責聲明 Sitemap
    PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!