WordPress 4.4新增了不少功能,之前也介紹過禁用REST API的方法,現在再來介紹一下禁用embeds的方法,也就是移除頁面輸出的wp-embed.min.js文件。wordpress 4.4的embeds功能可以允許更方便的引用第三方資源,具體可以搜下oEmbed,這里不細說了。
禁用embeds其實還是比較復雜(代碼比較多),官方甚至為此開發了一個插件,大家可以使用插件來禁用:Disable Embeds,如果不想使用插件,那就將插件里面的代碼復制到主題的functions.php文件即可。
代碼如下:
function disable_embeds_init() { /* @var WP $wp */ global $wp; // Remove the embed query var. $wp->public_query_vars = array_diff( $wp->public_query_vars, array( 'embed', ) ); // Remove the REST API endpoint. remove_action( 'rest_api_init', 'wp_oembed_register_route' ); // Turn off add_filter( 'embed_oembed_discover', '__return_false' ); // Don't filter oEmbed results. remove_filter( 'oembed_dataparse', 'wp_filter_oembed_result', 10 ); // Remove oEmbed discovery links. remove_action( 'wp_head', 'wp_oembed_add_discovery_links' ); // Remove oEmbed-specific JavaScript from the front-end and back-end. remove_action( 'wp_head', 'wp_oembed_add_host_js' ); add_filter( 'tiny_mce_plugins', 'disable_embeds_tiny_mce_plugin' ); // Remove all embeds rewrite rules. add_filter( 'rewrite_rules_array', 'disable_embeds_rewrites' ); } add_action( 'init', 'disable_embeds_init', 9999 ); /** * Removes the 'wpembed' TinyMCE plugin. * * @since 1.0.0 * * @param array $plugins List of TinyMCE plugins. * @return array The modified list. */ function disable_embeds_tiny_mce_plugin( $plugins ) { return array_diff( $plugins, array( 'wpembed' ) ); } /** * Remove all rewrite rules related to embeds. * * @since 1.2.0 * * @param array $rules WordPress rewrite rules. * @return array Rewrite rules without embeds rules. */ function disable_embeds_rewrites( $rules ) { foreach ( $rules as $rule => $rewrite ) { if ( false !== strpos( $rewrite, 'embed=true' ) ) { unset( $rules[ $rule ] ); } } return $rules; } /** * Remove embeds rewrite rules on plugin activation. * * @since 1.2.0 */ function disable_embeds_remove_rewrite_rules() { add_filter( 'rewrite_rules_array', 'disable_embeds_rewrites' ); flush_rewrite_rules(); } register_activation_hook( __FILE__, 'disable_embeds_remove_rewrite_rules' ); /** * Flush rewrite rules on plugin deactivation. * * @since 1.2.0 */ function disable_embeds_flush_rewrite_rules() { remove_filter( 'rewrite_rules_array', 'disable_embeds_rewrites' ); flush_rewrite_rules(); } register_deactivation_hook( __FILE__, 'disable_embeds_flush_rewrite_rules' );
這里不得不吐槽下wordpress,如果每次升級都增加一些功能,并且要在頁面輸出內容,那必然會影響網站的打開速度,更坑的是如果禁用需要安裝插件,那么每次升級都要安裝幾個插件?
在wordpress的功能介紹文章下面也有不少用戶提出這個問題,有興趣的童鞋可以去看下:https://make.wordpress.org/core/2015/10/28/new-embeds-feature-in-wordpress-4-4/
評論列表(16)
復制了直接白屏
建議直接安裝插件:https://wordpress.org/plugins/disable-embeds/
管理學書籍http://www.12reads.cn直接用下面的代碼就OK了,不需要這么麻煩吧?
add_action( ‘wp_print_scripts’, ‘my_deregister_javascript’, 100 );
function my_deregister_javascript() {
wp_deregister_script( ‘wp-embed’ );
}
你的方法從代碼上看是移除了js文件,但是并沒有禁用embeds功能
可是哪里也看不到了,怎么知道沒有禁用成功呢?源碼里沒有embeds了。
想要知道有沒有禁用成功首先需要知道這個功能的作用,他不僅僅是一段js文件可以實現的,Embeds的具體介紹可以參考官方文檔:http://codex.wordpress.org/Embeds
請問這是用的什么代碼高亮插件
Crayon Syntax Highlighter
升級4.4后,我在后臺登陸跳轉到首頁依然還是顯示沒有登陸。怎么回事了
是沒有登錄還是沒有顯示登錄后的用戶條呢
找到原因了 數據庫緩存插件,但是沒有升級前 都沒有這個問題,升級后就出現這個問題了。
請問貴站使用緩存插件了嗎?
你這個帖代碼的不行啊,我復制了直接白屏,害我還原了之后一行一行復制出來。。。
直接安裝那個插件吧,代碼換行有點問題
問題解決了,現在可以正常復制了
為什么這里復制代碼不帶換行符,還得手動添加換行。。。。
額,好像是,看來要優化一下了