+91 88 00 563434 sales@webhostingpeople.net

Our Knowledge Base Articles

Company Blog

How to Protect WordPress from XML-RPC Attacks

You are here:

WordPress is the most well-liked Content material Administration System. This reputation makes WordPress an ideal goal for hackers. The most typical assault confronted by a WordPress web site is XML-RPC assault.

Recognizing an XML-RPC Assault

1) Randomly “Error establishing database connection” error is displaying on the WordPress web site.

2) “Out of reminiscence” error within the net console.

3) “Can’t open the file no such file/listing” error in net server error log.

4) “POST /xmlrpc.php HTTP/1.0” error in webserver entry log.

What’s XML-RPC?

WordPress makes use of a distant execution name referred to as XML-RPC that’s used to change info between laptop methods over a community. XML-RPC is a distant process name that makes use of HTTP for transport and XML for encoding. This performance might be exploited to ship hundreds of brute pressure assault in a short while. Hackers attempt to login to WordPress admin portal utilizing xmlrpc.php with any username/password. Xmlrpc.php permits hackers to guess lots of of passwords with solely Three or Four HTTP requests resulting in a excessive database load. Then your WordPress web site will randomly go down and parse the error “error establishing database connection”


Command to go looking XML-RPC assault in numerous Linux distribution

For apache on centos:

# grep xmlrpc /var/logs/httpd/entry.log

For apache on Ubuntu:

# grep xmlrpc /var/logs/apache2/entry.log

For cPanel server

# grep xmlrpc /residence/username/logs/entry.log

For nginx server:

# grep xmlrpc /var/logs/nginx/entry.log

If the WordPress web site is dealing with assault, then the output of the above command might be just like

“POST /xmlrpc.php HTTP/1.0” 200 674 “-” “Mozilla/4.0 (suitable: MSIE 7.0; Home windows NT 6.0)”


Blocking XML-RPC assault

We will block XML-RPC assault in numerous methods.

1)  Manually block the xmlrpc within the .htaccess file

Right here you’ll be able to deny the entry of xmlrpc file from all customers. Merely paste the next code within the .htaccess file within the web site doc root.

# Block WordPress xmlrpc.php requests

<Information xmlrpc.php>

order deny,permit

deny from all


# END shield xmlrpc.php

2)Manually block xmlrpc in webserver doc root.

For Apache paste the code within the configuration file.


<recordsdata xmlrpc.php>

order permit,deny

deny from all



For Nginx paste the beneath code within the configuration file.


location /xmlrpc.php

deny all;

After modifying the configuration recordsdata you want to restart the webserver with a view to allow the adjustments.

3) Putting in Jetpack Plugin.

Jetpack plugin for WordPress will block the XML-RPC requests. After enabling the jetpack plugin, you’ll nonetheless see the XML-RPC entries within the net server entry log. The plugin reduces the load on the database from these malicious logs.

Confirm Assault diminution

After enabling Jetpack plugin, the XML-RPC content material remains to be remaining on the entry log of the net server. The plugin reduces the load of the database and the plugin will block the attacking IP addresses. In case you manually block the XML-RPC in webserver configuration file or within the .htaccess file, your logs will nonetheless present the requests, however the ensuing error code might be one thing aside from 200. Will probably be 403,500 or 404. Then the result’s just like the code beneath.

“POST /xmlrpc.php HTTP/1.1” 403 291 “-”674 “-” “Mozilla/4.0 (suitable: MSIE 7.0; Home windows NT 6.0)”

By decreasing the malicious XML-RPC site visitors your WordPress web site might be safer and it consumes fewer system sources. Consequently, the WordPress web site stays on-line.

In case you want any additional help please contact our assist division.

Leave a Comment