WordPress 頭部的程式碼非常多,包括 WordPress 版本,前後文、第一篇文章、主頁 meta 資訊等各種冗餘程式碼,這些對博主來說是沒有意義的,也對網站的安全有一定的影響,也一度不知道這些程式碼是有什麼作用、怎麼來的和怎麼刪除。
將以下程式碼插入到你 functions.php 的檔案頭部,除 WordPress 頭部大量冗餘資訊
<?php
//remove_action( 'wp_head', 'wp_enqueue_scripts', 1 );
remove_action( 'wp_head', 'feed_links', 2 );
remove_action( 'wp_head', 'feed_links_extra', 3 );
remove_action( 'wp_head', 'rsd_link' );
remove_action( 'wp_head', 'wlwmanifest_link' );
remove_action( 'wp_head', 'index_rel_link' );
remove_action( 'wp_head', 'parent_post_rel_link', 10, 0 );
remove_action( 'wp_head', 'start_post_rel_link', 10, 0 );
remove_action( 'wp_head', 'adjacent_posts_rel_link_wp_head', 10, 0 );
//remove_action( 'wp_head', 'locale_stylesheet' );
remove_action( 'publish_future_post', 'check_and_publish_future_post', 10, 1 );
//remove_action( 'wp_head', 'noindex', 1 );
//remove_action( 'wp_head', 'wp_print_styles', 8 );
//remove_action( 'wp_head', 'wp_print_head_scripts', 9 );
remove_action( 'wp_head', 'wp_generator' );
//remove_action( 'wp_head', 'rel_canonical' );
remove_action( 'wp_footer', 'wp_print_footer_scripts' );
remove_action( 'wp_head', 'wp_shortlink_wp_head', 10, 0 );
remove_action( 'template_redirect', 'wp_shortlink_header', 11, 0 );
add_action('widgets_init', 'my_remove_recent_comments_style');
function my_remove_recent_comments_style() {
global $wp_widget_factory;
remove_action('wp_head', array($wp_widget_factory->widgets['WP_Widget_Recent_Comments'], 'recent_comments_style'));
}
?>
各函式解釋:
wp_head 函式
wp_head() 是 WordPress 的一個非常重要的函式,基本上所有的主題在 header.php 這個檔案裡都會使用到這個函式,而且很多外掛為了在 header 上加 點東西也會用到 wp_head(),比如 SEO 的相關外掛。但是,在 wp_head() 出現的這個位置,會增加很多並不常用的程式碼。可以透過 remove_action 移除這些程式碼。
remove_action 函式
函式原型:
remove_action( $tag, $function_to_add, $priority, $accepted_args );
該函式移除一個附屬於指定動作 hook 的函式。該方法可用來移除附屬於特定動作 hook 的預設函式,並可能用其它函式取而代之。參見
remove_filter(), add_action() and add_filter() 。
重要:新增 hook 時的 $function_to_remove 和 $priority 引數要能夠相匹配,這樣才可以移除 hook 。該原則也適用於過濾器和動作。移除失敗時不進行警告提示。
引數
$tag(字串)(必需) 將要被刪除的函式所連線到的動作 hook 。預設值:None
$function_to_remove(回撥)(必需) 將要被刪除函式的名稱預設值:None
$priority(整數)(可選) 函式優先順序 (在函式最初連線時定義) 預設值:10
$accepted_args(整數)(必需) 函式所接受引數的數量。預設值:1
返回值
(布林值) 函式是否被移除。
Ttue 函式被成功移除
False 函式未被移除
移除 WordPress 版本
在 head 區域,可以看到如下程式碼:
<meta name="generator" content="WordPress 3.1.2" />
這是隱性顯示的 WordPress 版本資訊,預設新增。可以被駭客利用,攻擊特定版本的 WordPress 漏洞。清除程式碼:
remove_action( 'wp_head', 'wp_generator' );
移除離線編輯器開放介面
WordPress 自動新增兩行離線編輯器的開放介面
<link rel="EditURI" type="application/rsd+xml" title="RSD" href="http://wpnoob.cn/xmlrpc.php?rsd" /> <link rel="wlwmanifest" type="application/wlwmanifest+xml" href="http://wpnoob.cn/wp-includes/wlwmanifest.xml" />
其 中 RSD 是一個廣義的介面,wlwmanifest 是針對微軟 Live Writer 編輯器的。如果你不需要離線編輯,可移除之。即便你需要使用離線編輯器,大部分時候也不需要這兩行程式碼。 Live Writer 自己知道它們。保留這兩行程式碼可能會留有安全隱患。清除程式碼:
remove_action( 'wp_head', 'rsd_link' ); remove_action( 'wp_head', 'wlwmanifest_link' );
移除前後文、第一篇文章、主頁 meta 資訊
WordPress 把前後文、第一篇文章和主頁連結全放在 meta 中。我認為於 SEO 幫助不大,反使得頭部資訊巨大。移除程式碼:
remove_action( 'wp_head', 'index_rel_link' ); // Removes the index link remove_action( 'wp_head', 'parent_post_rel_link', 10, 0 ); // Removes the prev link remove_action( 'wp_head', 'start_post_rel_link', 10, 0 ); // Removes the start link remove_action( 'wp_head', 'adjacent_posts_rel_link_wp_head', 10, 0 ); // Removes the relational links for the posts adjacent to the current post.
移除 Canonical 標記
09 年 2 月份,Google,Yahoo 及 Microsoft 三大搜尋引擎聯合推出了一個旨在減少重複內容困擾的方法,這對於廣大站長來說不啻是個好事情,不用再擔心因為網站上有重複的內容而影響到網站頁面的權重了。
造 成重複內容的原因有很多,最常見的便是多個 url 地址指向了同一個頁面,比如:WordPress 平臺下的一篇日誌頁面,包括了文章及評論內容。每個評論 都可以有個固定的連結地址,,如果有多個評論的話,則每條評論的連結都類似於上述格式,只是 commentID 號有所不同,這些連結其實都是指向同一篇文 章的。蜘蛛來爬時,便會依次爬行一遍,這篇文章下如有 10 條評論,則爬了 10 次相同的頁面文章,相當於做了多次重複的工作,嚴重影響了抓取的效率,及耗費 了頻寬。
重複內容造成的結果必然是蜘蛛不願意來爬,不同的 url 指向同一個頁面,也會影響到該頁面的權重。透過 canonical 標籤,能有效的避免這類問題。
需要注意兩點:
允許指向不同的子域名,不允許指向其他域名
canonical 屬性可以被傳遞
即 A 頁面宣告 B 為權威連結,B 宣告 C 為權威網頁,那麼 C 就是 A 和 B 共同的首選權威版本
如果你的 WP 版本在 2.9 之前,需要透過外掛 (上面已經提到) 或者手工 Hack 主題的 header.php 檔案來使得部落格支援。
<link rel="canonical" href="<?php%20get_permalink()?>" />
在 WordPress 2.9 釋出之後,WordPress 已經預設支援這一標籤了,我們無需做任何動作,主題就支援這一標籤。這對於文章固定連結的更改很有幫助,可以增加對搜尋引擎的友好度。但是如果你覺得這個標籤對你無用,也可以移除之:
remove_action( 'wp_head', 'rel_canonical' );
移除 feed
HTML 中透過
<link rel="alternate" type="application/rss+xml" title="feed 名" href="http://wpnoob.cn/feed/" />
來指定部落格 feed 。可以被瀏覽器檢測到,然後被讀者訂閱。
如果你不想新增 feed,或者想使用燒製的 feed(如 FeedSky 或者 Feedburner 燒製的 feed),可以移除之。
remove_action( 'wp_head', 'feed_links', 2 );//文章和評論 feed remove_action( 'wp_head', 'feed_links_extra', 3 ); //分類等 feed
如果用的燒製的 feed,然後還可以再手動新增 feed 地址。