Wordpress自動(dòng)將包含長(zhǎng)鏈接的評(píng)論標(biāo)記為垃圾評(píng)論的方法
本文實(shí)例講述了Wordpress自動(dòng)將包含長(zhǎng)鏈接的評(píng)論標(biāo)記為垃圾評(píng)論的方法。分享給大家供大家參考。具體分析如下:
現(xiàn)在大量的機(jī)器可以直接對(duì)WordPress博客進(jìn)行評(píng)論并帶有大量的連接,這些帶鏈接評(píng)論我們定為垃圾評(píng)論了,這里就來(lái)給大家介紹幾個(gè)自動(dòng)將包含長(zhǎng)鏈接的評(píng)論標(biāo)記為垃圾評(píng)論的方法.
方法一:此方法依舊是來(lái)自 Willin Kan 大師(可惜他已經(jīng)退出WordPress圈),折騰很簡(jiǎn)單,直接將下面的代碼放到主題的functions.php文件的最后一個(gè) ?>前面即可,代碼如下:
class anti_spam {
function anti_spam() {
if ( !current_user_can('level_0') ) {
add_action('template_redirect', array($this, 'w_tb'), 1);
add_action('init', array($this, 'gate'), 1);
add_action('preprocess_comment', array($this, 'sink'), 1);
}
}
function w_tb() {
if ( is_singular() ) {
ob_start(create_function('$input','return preg_replace("#textarea(.*?)name=(["'])comment(["'])(.+)/textarea>#",
"textarea$1name=$2w$3$4/textarea><textarea name="comment" cols="100%" rows="4" style="display:none"></textarea>",$input);') );
}
}
function gate() {
if ( !emptyempty($_POST['w']) && emptyempty($_POST['comment']) ) {
$_POST['comment'] = $_POST['w'];
} else {
$request = $_SERVER['REQUEST_URI'];
$referer = isset($_SERVER['HTTP_REFERER']) ? $_SERVER['HTTP_REFERER'] : '隱瞞';
$IP = isset($_SERVER["HTTP_X_FORWARDED_FOR"]) ? $_SERVER["HTTP_X_FORWARDED_FOR"] . ' (透過(guò)代理)' : $_SERVER["REMOTE_ADDR"];
$way = isset($_POST['w']) ? '手動(dòng)操作' : '未經(jīng)評(píng)論表格';
$spamcom = isset($_POST['comment']) ? $_POST['comment'] : null;
$_POST['spam_confirmed'] = "請(qǐng)求: ". $request. "n來(lái)路: ". $referer. "nIP: ". $IP. "n方式: ". $way. "n?熱? ". $spamcom. "n -- 記錄成功 --";
}
}
function sink( $comment ) {
if ( !emptyempty($_POST['spam_confirmed']) ) {
if ( in_array( $comment['comment_type'], array('pingback', 'trackback') ) ) return $comment;
//方法一: 直接擋掉, ? die(); 前面兩斜線?h除即可.
die();
//方法二: 標(biāo)記為 spam, 留在資料庫(kù)檢查是否誤判.
//add_filter('pre_comment_approved', create_function('', 'return "spam";'));
//$comment['comment_content'] = "[ 小墻判斷這是 Spam! ]n". $_POST['spam_confirmed'];
}
return $comment;
}
}
$anti_spam = new anti_spam();
這個(gè)方法可以阻止98%以上的垃圾評(píng)論,當(dāng)然了,倡萌還建議你審核第一次提交的評(píng)論人的評(píng)論,設(shè)置審核后才顯示,如果遇到垃圾評(píng)論,將其email、IP、網(wǎng)址等添加到黑名單即可,下面是倡萌目前的評(píng)論設(shè)置,你可以在WP后臺(tái)-設(shè)置-討論下設(shè)置.
方法二:自動(dòng)拒絕包含特定關(guān)鍵詞的垃圾評(píng)論,將下面的代碼添加到主題的functions.php文件,自己根據(jù)需要,修改 $ bad_comment_content 數(shù)組的內(nèi)容,任何包含在$ bad_comment_content 數(shù)組內(nèi)的字符,將會(huì)被自動(dòng)拒絕留言,代碼如下:
foreach($array as $ref) { if(strstr($string, $ref)) { return true; } }
return false;
}
function drop_bad_comments() {
if (!emptyempty($_POST['comment'])) {
$post_comment_content = $_POST['comment'];
$lower_case_comment = strtolower($_POST['comment']);
$bad_comment_content = array(
'viagra',
'hydrocodone',
'hair loss',
'xanax',
'tramadol',
'russian girls',
'russian brides',
'lorazepam',
'adderall',
'dexadrine',
'no prescription',
'oxycontin',
'without a prescription',
'sex pics',
'family incest',
'online casinos',
'online dating',
'cialis',
'best forex',
'amoxicillin'
);
if (in_comment_post_like($lower_case_comment, $bad_comment_content)) {
$comment_box_text = wordwrap(trim($post_comment_content), 80, "n ", true);
$txtdrop = fopen('/var/log/httpd/wp_post-logger/nullamatix.com-text-area_dropped.txt', 'a');
fwrite($txtdrop, " --------------n [COMMENT] = " . $post_comment_content . "n --------------n");
fwrite($txtdrop, " [SOURCE_IP] = " . $_SERVER['REMOTE_ADDR'] . " @ " . date("F j, Y, g:i a") . "n");
fwrite($txtdrop, " [USERAGENT] = " . $_SERVER['HTTP_USER_AGENT'] . "n");
fwrite($txtdrop, " [REFERER ] = " . $_SERVER['HTTP_REFERER'] . "n");
fwrite($txtdrop, " [FILE_NAME] = " . $_SERVER['SCRIPT_NAME'] . " - [REQ_URI] = " . $_SERVER['REQUEST_URI'] . "n");
fwrite($txtdrop, '--------------**********------------------'."n");
header("HTTP/1.1 406 Not Acceptable");
header("Status: 406 Not Acceptable");
header("Connection: Close");
wp_die( __('bang bang.') );
}
}
}
add_action('init', 'drop_bad_comments');
今天再補(bǔ)充下,自動(dòng)將包含長(zhǎng)鏈接的評(píng)論標(biāo)記為垃圾評(píng)論,將下面的代碼添加到主題的 functions.php 文件即可:
return ( strlen( $commentdata['comment_author_url'] ) > 50 ) ? 'spam' : $approved;
}
add_filter( 'pre_comment_approved', 'rkv_url_spamcheck', 99, 2 );
注意看第二行的 50,根據(jù)自己的需要修改這個(gè)數(shù)值,如果你希望將所有帶有鏈接(不管是否是長(zhǎng)鏈接)的評(píng)論內(nèi)容都自動(dòng)標(biāo)記為垃圾評(píng)論,將 50 改為 1 即可.
希望本文所述對(duì)大家的WordPress建站有所幫助。
上一篇:WordPress 網(wǎng)站如何防范大規(guī)模暴力破解攻擊
欄 目:WordPress
本文標(biāo)題:Wordpress自動(dòng)將包含長(zhǎng)鏈接的評(píng)論標(biāo)記為垃圾評(píng)論的方法
本文地址:http://mengdiqiu.com.cn/a1/WordPress/12693.html
您可能感興趣的文章
- 05-31wordpress修改后臺(tái)登錄地址教程
- 05-31WordPress自定義用戶頭像實(shí)現(xiàn)代碼
- 01-11修改wordpress上傳臨時(shí)目錄解決wordpress無(wú)法安裝插件包的方法
- 01-11WordPress增加文章排序方式
- 01-11自己做wordpress評(píng)論插件修改評(píng)論樣式(兩步美化評(píng)論內(nèi)容)
- 01-11wordpress get
- 01-11wordpress獲取文章評(píng)論數(shù)過(guò)濾掉作者代碼分享
- 01-11在wordpress文章末尾添加內(nèi)容的簡(jiǎn)單方法
- 01-11不用wordpress插件顯示文章瀏覽統(tǒng)計(jì)功能代碼修改(原理分析)
- 01-11wordpress dynamic


閱讀排行
- 1C語(yǔ)言 while語(yǔ)句的用法詳解
- 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹(shù)的示例代碼(圣誕
- 3利用C語(yǔ)言實(shí)現(xiàn)“百馬百擔(dān)”問(wèn)題方法
- 4C語(yǔ)言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
- 5c語(yǔ)言計(jì)算三角形面積代碼
- 6什么是 WSH(腳本宿主)的詳細(xì)解釋
- 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
- 8正則表達(dá)式匹配各種特殊字符
- 9C語(yǔ)言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
- 10C語(yǔ)言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
本欄相關(guān)
- 05-31wordpress修改后臺(tái)登錄地址教程
- 05-31WordPress自定義用戶頭像實(shí)現(xiàn)代碼
- 01-11WordPress增加文章排序方式
- 01-11修改wordpress上傳臨時(shí)目錄解決wordpre
- 01-11wordpress get
- 01-11自己做wordpress評(píng)論插件修改評(píng)論樣式
- 01-11在wordpress文章末尾添加內(nèi)容的簡(jiǎn)單方
- 01-11wordpress獲取文章評(píng)論數(shù)過(guò)濾掉作者代
- 01-11wordpress dynamic
- 01-11不用wordpress插件顯示文章瀏覽統(tǒng)計(jì)功
隨機(jī)閱讀
- 01-11Mac OSX 打開(kāi)原生自帶讀寫NTFS功能(圖文
- 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?
- 01-10SublimeText編譯C開(kāi)發(fā)環(huán)境設(shè)置
- 01-10使用C語(yǔ)言求解撲克牌的順子及n個(gè)骰子
- 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
- 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
- 01-10C#中split用法實(shí)例總結(jié)
- 01-11ajax實(shí)現(xiàn)頁(yè)面的局部加載
- 01-10delphi制作wav文件的方法
- 04-02jquery與jsp,用jquery