注册 登录 欢迎您访问极限源码网:专注各类网站源码下载。

织梦基础知识

该栏目分享织梦建站的基础知识,从织梦CMS的安装,到织梦标签的常规调用,以及织梦的常见问题答疑都有涉及。

当前位置:网站首页 > 建站学院 > 织梦教程 >

修复DEDECMS5.5采集功能的一些bug

极限源码 2019-05-01 09:12 织梦教程

修复1:将开始标签和结束标签以在网页源码中第一次出现的位置为准 

修改文件\include\dedecollection.class.php 

在成员函数GetHtmlArea中的 

$posend = @strpos($html,$areaRules[1],$posstart); 

语句前增加语句: 

$posstart=$posstart+strlen($areaRules[0]); 

将: 

return substr($html,$posstart+strlen($areaRules[0]),$posend-$posstart-strlen($areaRules[0])); 

替换为: 

return substr($html,$posstart,$posend-$posstart); 

 

修复2:下载图片时对图片的扩展名判断错误 

相同文件 

将 

 

eregi("\.gif",$v) 

替换为 

eregi("\.gif$",$url) 

 

eregi("\.png",$v) 

替换为 

eregi("\.png$",$url)

 

修复3:采集软件地址的正则表达式不准确 

\include\dedecollection.func.php 

将TurnLinkTag函数中 

preg_match_all("/<a(?:.*)href=['\"](.+?)['\"]([^>]+?)>(.+?)<\/a>/is",$body,$match);

换为: 

preg_match_all("/<a(?:[^\>]+?)href\\s*=\\s*[\'\"]?([^\\s\>\"\']+)([^\>]+?)>(.+?)<\/a>/is",$body,$match);

修复4:采集图片的正则表达式不准确

相同文件

preg_match_all('/src=[\'"](.+?)[\'"]/is',$body,$match);

 $ttx = '';

 if(is_array($match[1]) && count($match[1])>0)

 {

  for($i=0;isset($match[1][$i]);$i++)

  {

   $ttx .= "{dede:img text='' }".$match[1][$i]." {/dede:img}"."\r\n";

  }

 }

改为

$patten = "/<\\s*img\\s.*?src\\s*=\\s*([\"\\'])?(?(1)(.*?)\\1|([^\\s\\>\"\\']+))/isx";

    preg_match_all( $patten, $body, $images );

    $returnArray1 = $images[2];

    $returnArray2 = $images[3];

    foreach ( $returnArray1 as $key => $value )

    {

        if ( $value )

        {

            $ttx .= "{dede:img ddimg='$litpicname' text='图 ".($key+1)."'}".$value."{/dede:img}"."\r\n";

        }

        else

        {

            $ttx .= "{dede:img ddimg='$litpicname' text='图 ".($key+1)."'}".$returnArray2[$key]."{/dede:img}"."\r\n";

        }


服务项目

源码下载

关于我们

极限源码网| https://www.jxym.net

极限源码网(JXYM.NET)由一批热爱网页设计、敢于追求梦想、努力付诸行动的热火青年联合打造,在我们的努力之下,让您拥有一个全方位的源码下载平台