0712-2888027 189-8648-0214
微信公眾號

孝感風信網(wǎng)絡(luò)科技有限公司微信公眾號

當前位置:主頁 > 技術(shù)支持 > PHPCMS > PHPCMS使用心得與技巧,以及小BUG的糾正

PHPCMS使用心得與技巧,以及小BUG的糾正

時間:2015-11-09來源:風信官網(wǎng) 點擊: 875次

用PHPCMS開發(fā)的第一個項目是一個素材類網(wǎng)站 ,之所以選PHPCMS估計是因為看了她的百萬級的數(shù)據(jù)測試報告。而之后,我越用感覺也越不錯。當然,期間遇到過不少問題, 總結(jié)了一下,方便以后開發(fā)。(版本:phpcms2008sp3_gbk)

綜合問題

使用GET標簽時靜態(tài)分頁出錯以及分頁地址會鏈接到后臺

文件:/include/global.func.php
函數(shù):pages
在 if($curr_page>0) 前添加 $url = load('url.class.php'),如下:
$url = load('url.class.php');
if($curr_page>0)
只要添加一行代碼就解決了,而在網(wǎng)上找的解決方法卻非常復雜,好郁悶!

而分頁地址會鏈接到后臺則只需要將以下的第一行代碼替換成第二行就OK了,當然,建議把第一行注釋掉,加上第二行。

代碼如下:

$multipage .= ' <u><b>'.$pages.'</b></u><a href="'.pageurl($urlrule, $curr_page, $array).'">下一頁</a>';
$multipage .= $catid ?' <u><b>'.$pages.'</b></u><a href="'.$url->category($catid, $curr_page, 1, 1).'">下一頁</a>' : ' <u><b>'.$pages.'</b></u><a href="'.pageurl($urlrule, $curr_page, $array).'">下一頁</a>';

上傳文件路徑修改

文件:include/attachment.class.php
找到 $this->savepath 和 $dir 這兩個變量,以下是修改后的值,路徑為“uploadfile/年/月/日/”:
$this->savepath = UPLOAD_ROOT.date('Y/md/');
$dir = date('Y/m/d/', TIME);

將縮略圖保存到單獨的文件夾,這樣子也方便管理
文件:/include/global.func.php
$newimgurl = dirname($imgurl).'/thumb/thumb_'.$width.'_'.$height.'_'.basename($imgurl);

文件:/include/attachment.class.php
以下是 get_thumb 函數(shù)修改后的代碼

代碼如下:

function get_thumb($image)
{
/* 縮略圖文件夾 */
$thumbdir = dirname($image).'/thumb';
if (!file_exists($thumbdir)) mkdir($thumbdir, 0700);
return dirname($image).'/thumb/thumb_'.basename($image);
//return str_replace('.', '_thumb.', $image);
}

BUG (UPLOAD_PATH 不存在)

記不清報什么錯了,反正后來我是直接把 UPLOAD_PATH 這個常量刪掉,最后就正常了。有知道提示什么錯誤的請留個言。
提示錯誤:Warning: mkdir() [function.mkdir]: No such file or directory in... 類似這樣子的
只要把UPLOAD_PATH去掉然后更新緩存,一切正常。

/include/fields/images/output.inc.php
$thumb = UPLOAD_URL.$attachment->get_thumb(UPLOAD_PATH.$a['filepath']);

全站搜索最多顯示的記錄數(shù)

PHPCMS 的全站搜索很強大,貌似能支持百萬級的數(shù)據(jù)量。通常,搜索結(jié)果不需要輸出全部記錄數(shù)的,所以我將搜索輸出結(jié)果設(shè)置為最多1000條(已經(jīng)很多了,GOOGLE都沒這么多,呵呵),以下是修改后的部分代碼。

代碼如下:

文件:/search/index.php
$page = max(intval($page), 1);
$page = $page>100 ? 100 : $page; (增加了這行代碼)
文件:/search/include/search.class.php
$this->total = cache_count("SELECT COUNT(*) AS `count` FROM `$this->table` WHERE $where");
$this->total = $this->total>1000 ? 1000 : $this->total; (增加了這行代碼)

采集模塊

該如何去設(shè)置采集規(guī)則就不多說了,官方有詳細介紹:http://www.phpcms.cn/2009/0522/220.html

需要采集的話使用GBK版本的PHPCMS

試過用UTF-8版本的去采集,結(jié)果不論怎么調(diào),采回來的中文都是亂碼,好郁悶。沒有深入研究,轉(zhuǎn)投GBK。

修改采集圖片和壓縮文件時的保存路徑

文件:/spider/include/get_remotefiles.func.php
函數(shù):do_saveremotefiles
修改函數(shù)中以下兩個變量;以下是我修改后的結(jié)果,保存路徑為“uploadfile/年/月/日/”:

代碼如下:

$filepath = PHPCMS_PATH . $uploaddir . '/' . date('Y/m/d') . '/';
$uploaddir = PHPCMS_ROOT . '/' . $uploaddir . '/' . date('Y/m/d') . '/';

采集內(nèi)容時無法遠程保存圖片

src 前的空格導致了圖片在采集內(nèi)容時采集不了,只有在發(fā)布時才能采集得到。
文件:/spider/include/get_remotefiles.func.php
函數(shù):get_remotefileurls
以下分別是修改前和修改后的代碼,注意src前的空格,只要把空格去掉就OK了。

代碼如下:

if (!preg_match_all("/<(?:a|img).+?(href| src)=([\"|']?)([^ \"'>]+\.($ext))\\2/i", $string, $matches))
if (!preg_match_all("/<(?:a|img).+?(href|src)=([\"|']?)([^ \"'>]+\.($ext))\\2/i", $string, $matches))

遠程保存非內(nèi)容中的圖片和文件

采集模塊默認只會保存“內(nèi)容”標簽中的圖片和文件,而其它標簽中不論出現(xiàn)多少次img或a都不會被采集。如果你需要把圖片和文件分別保存到其它字段,這個修改貌似挺有用的。
文件:/spider/admin/mainspider.inc.php
行數(shù):372行
以下是修改結(jié)果:

代碼如下:

$v = get_remotefiles($v, 'gif|jpg|jpeg|bmp|png|rar|zip', $dourl, $basehref, true);

抓取不到頁面時采集狀態(tài)改為未采集

如果被采集網(wǎng)站不穩(wěn)定,有時會出現(xiàn)抓取不到采集頁面的情況,而此時采集狀態(tài)還是會被標記為已采集。所以只要小小修改一下,我們會方便很多。
文件:/spider/admin/mainspider.inc.php
行數(shù):664行
以下是修改結(jié)果,添加了“&& (trim($body)!=''”這一句:

代碼如下:

if (($body!=$LANG['title_or_content_null']) && (trim($body)!=''))
熱門關(guān)鍵詞: PHPCMS 使用心得 BUG
欄目列表
推薦內(nèi)容
熱點內(nèi)容
展開