<?php
/*
Plugin Name: [RPC] XMLRPCless Blog
Plugin URI: http://earnestodev.com/
Description: Disable XMLRPC advertising/functionality blog-wide.
Version: 0.0.7
Author: EarnestoDev
Author URI: http://earnestodev.com/
*/
// Disable X-Pingback HTTP Header.
add_filter('wp_headers', function($headers, $wp_query){
if(isset($headers['X-Pingback'])){
// Drop X-Pingback
unset($headers['X-Pingback']);
}
return $headers;
}, 11, 2);
// Disable XMLRPC by hijacking and blocking the option.
add_filter('pre_option_enable_xmlrpc', function($state){
return '0'; // return $state; // To leave XMLRPC intact and drop just Pingback
});
// Remove rsd_link from filters (<link rel="EditURI" />).
add_action('wp', function(){
remove_action('wp_head', 'rsd_link');
}, 9);
// Hijack pingback_url for get_bloginfo (<link rel="pingback" />).
add_filter('bloginfo_url', function($output, $property){
return ($property == 'pingback_url') ? null : $output;
}, 11, 2);
// Just disable pingback.ping functionality while leaving XMLRPC intact?
add_action('xmlrpc_call', function($method){
if($method != 'pingback.ping') return;
wp_die(
'Pingback functionality is disabled on this Blog.',
'Pingback Disabled!',
array('response' => 403)
);
});
?>
Verwenden Sie dies für ein Plugin in / wp-content / plugins oder / wp-content / mu-plugins (für die automatische Aktivierung) . Oder functions.php .
Lustige Sache ist, dass ich eine WordPress Remote Publishing Library verkaufe und Ihnen den Code zum Deaktivieren von XMLRPC gab :) Schlecht für den Ruf.
return '0'
wird nicht wie erwartet funktionieren. Die Zeichenfolge'0'
gibt true zurück.add_filter( 'pre_option_enable_xmlrpc', '__return_false' );
@EarnestoDev hatte eine großartige Antwort , aber seit den letzten xml-rcp Exploits ist es ein bisschen veraltet .
Ich habe eine aktualisierte Version erstellt, die meines Erachtens den gesamten möglichen Zugriff darauf blockiert. Beachten Sie jedoch, dass es einige Plugins gibt, die die XML-RPC-Pingback- / Trackback-Funktionalität verwenden und Probleme verursachen können, wenn Sie sie verwenden:
Hier ist eine aktualisierte Version. Um es herunterzuladen, können Sie es in eine Plugin-Datei kopieren, in mu-plugins ablegen oder auf github herunterladen :
Wenn Sie alle vorhandenen Pingbacks schließen möchten, gehen Sie folgendermaßen vor:
1) Öffnen Sie phpmyadmin und navigieren Sie zum SQL-Bereich:
2) Geben Sie Folgendes ein:
3) Alle vorhandenen Pingbacks sollten jetzt geschlossen sein
quelle