名站网址导航为大驾家提供DedeCMS站点程序站点教程相关的知识,比如织梦程序安装教程,织梦程序系统故障等教程。
在使用DEDECMS时,很多时候从一些站点复制的网站内容时,其中的图片,保存时不能把远程图片下载到本地,像新浪博客,网易等一些大型站点图片有做防盗链处理,图片地址并没有后辍名!因此在使用dedecms网站程序默认的下载远程功能没办法实现!
在发现了此问题,分析了下,发现其实要解决很简单,发现DEDECMS在检索远程图片时的正则加了图片格式匹配;
DEDECMS匹配的正则:preg_match_all("/(src)=[\"|'| ]{0,}(http:\/\/([^>]*)\.(gif|jpg|png))/isU",$body,$img_array);
而向新浪博客图片:http://static2.photo.sina.com.cn/orignal/54a625bft848ec4ffa561&690&690 是没有图片后辍的,所在不能匹配下载了!
找到了问题,就知道怎么改了!
/获得文章body里的外部资源
function GetCurContent($body,&$litpic,$autolitpic)
//获得文章body里的外部资源
function GetCurContent($body)
大概在11行和89行把匹配远程图片的规则
preg_match_all("/(src)=[\"|'| ]{0,}(http:\/\/([^>]*)\.(gif|jpg|png))/isU",$body,$img_array);
改成
preg_match_all("/src=[\"|'|\s]{0,}(http:\/\/([^>]*))(\"|'|\s)/isU",$body,$img_array);
就OK了
当然DEDECMS这样做是有它道理的,这样只能匹配图片,不会匹配到像JS,FLASh网站文件,但这样也有很多不方便,因为咱们在编辑网站内容时,就能识别这是一个什么网站文件了!
关于DedeCMS站点程序站点教程相关的知识,就说到这里了希望能帮助朋友们。把数据保存到数据库主表 `dede_archives` 时出错最完整解决方案