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 地址。