织梦CMS采集没自动生成摘要和关键词的解决方法

DEDE5.6采集到了内容,可没自动生成摘要和关键词,关键词和摘要都是空的。

可能大多数人都遇见了和我一样的问题,在平台实在没找到好的解决方法,就自己动手去改改文件。废话不多说了。

下面是我的解决方法

譬如我采集了网站:http://www.52iphone8.com

首页的meta代码是:

Copy to Clipboard引用的内容:[www.dede58.com]<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>iphone苹果中文网</title>
<meta name=description content="苹果iPhone手机中文官方网站,为你提供苹果iPhone 4代手机最新价格,同时包括苹果iPhone手机图片、苹果iPhone手机参数、苹果iPhone手机主题、苹果iPhone手机APP、苹果iPhone手游、苹果iPhone手机测评行情、苹果iphone视频、苹果iphone铃声、苹果iPhone手机平台、苹果iPhone手机下载等信息。" />
<meta name=keywords content="苹果手机,iphone,苹果中文网,苹果手机官方网站,iphone4代,苹果iphone,iPhone手机,苹果手机价格,图片,平台,游戏,电影,主题,铃声,铃声,下载,软件,应用" />

假如用织梦CMS的采集的时候就没方法自动获得description和keywords的值的。
大伙注意到了这段代码和其它网站有什么区别了没??
<meta name=description content=... />
<meta name=keywords content=... />
就是name="description" 和 name="keywords" 少了双引号""
这个可能是织梦CMS中自动剖析关键词和摘要的一个bug吧,没考虑到<meta name=keywords content ='' />这样的情况!
采集的选项里面也没自己填写关键词和摘要的选项。那我只能自己动手修改文件了。
1、修改 include/dedecollection.class.php

Copy to Clipboard引用的内容:[www.dede58.com]//自动剖析关键词和摘要
preg_match['\"]/isU",$this->tmpHtml,$inarr);
preg_match['\"] name=['\"]keywords['\"]/isU",$this->tmpHtml,$inarr2);
if && isset)
{
$inarr[1] = $inarr2[1];
}

用下面一段代码替换上面的

Copy to Clipboard引用的内容:[www.dede58.com]//自动剖析关键词和摘要
preg_match['\"]/isU",$this->tmpHtml,$inarr); preg_match['\"] name=['\"]keywords['\"]/isU",$this->tmpHtml,$inarr2); preg_match['\"]/isU",$this->tmpHtml,$inarr3); if && isset) { $inarr[1] = $inarr2[1]; } if && isset) { $inarr[1] = $inarr3[1]; } 

改了上面的, 还有另一个地方需要修改的

Copy to ClipboardLiehuo.Net Codes引用的内容:[www.dede58.com]preg_match['\"]/isU",$this->tmpHtml,$inarr); preg_match['\"] name=['\"]description['\"]/isU",$this->tmpHtml,$inarr2); if && isset) { $inarr[1] = $inarr2[1]; } 

用下面的代码替换掉上面的:

Copy to ClipboardLiehuo.Net Codes引用的内容:[www.dede58.com]preg_match['\"]/isU",$this->tmpHtml,$inarr); preg_match['\"] name=['\"]description['\"]/isU",$this->tmpHtml,$inarr2); preg_match['\"]/isU",$this->tmpHtml,$inarr3); if && isset) { $inarr[1] = $inarr2[1]; } if && isset) { $inarr[1] = $inarr3[1]; }