top of page
Writer's pictureSiddhesh Kadam

Restricting Access in Nginx: How to Block Unwanted Traffic


Restricting Access in Nginx

When managing a web server, it's essential to protect your site from unwanted traffic and malicious activity. Nginx, a popular web server, offers powerful tools to help you manage and restrict access based on various criteria. In this guide, I'll explain how to use Nginx to block specific IP addresses, user agents, and HTTP request methods.


Step 1: Blocking Specific IP Addresses


IP addresses are unique identifiers assigned to devices connected to the internet. Sometimes, you may want to block specific IPs from accessing your website, especially if they are known for suspicious activity or belong to users who shouldn't have access.


In the Nginx configuration, you can block certain IP addresses like this:


if ($remote_addr ~* "(?:172.10.1.22|10.20.10.20)"){
    return 500;
}

Explanation:

$remote_addr refers to the IP address of the client making the request.

The ~* operator performs a case-insensitive regular expression match.

The list (?:172.10.1.22|10.20.10.20) includes the IP addresses you want to block.

return 500; sends a 500 Internal Server Error response to the client, effectively blocking them.


In this example, any request coming from the IP addresses 172.10.1.22 or 10.20.10.20 will be blocked, and the server will return a 500 error.


Step 2: Blocking Specific User Agents


User agents are strings that identify the software (like a web browser or bot) making the request. Some user agents, such as web crawlers or scanning tools, might be harmful or unwanted. Nginx allows you to block requests based on the user agent:

if ($http_user_agent ~* "(?:chrome|Mozilla|python-requests)") {
    return 403;
}

Explanation:

$http_user_agent is a variable that captures the user agent string of the client.

The list (?:chrome|Mozilla|python-requests) includes the user agents you want to block.

return 403; sends a 403 Forbidden response to the client, denying access.


In this example, any request coming from clients with user agents like chrome, Mozilla , or python-requests (a Python library for making HTTP requests) will be blocked with a 403 Forbidden error.


Step 3: Blocking Specific HTTP Request Methods


HTTP request methods like GET, POST, PUT, etc., define the action a client wants to perform on the server. Sometimes, you might want to block specific methods to prevent certain actions, like retrieving data using GET.


Here's how you can block GET requests:

if ($request ~* "(?:GET)") {
    return 500;
}

Explanation:


$request refers to the entire HTTP request line, including the method, URI, and protocol.

The list (?:GET) specifies the request method you want to block.

return 500; sends a 500 Internal Server Error response, blocking the request.


In this example, any GET request will be met with a 500 Internal Server Error, effectively preventing clients from retrieving data from the server.


Conclusion

By implementing these restrictions, you can enhance the security of your Nginx server by blocking specific IP addresses, user agents, and HTTP methods. This helps prevent unwanted traffic and reduces the risk of malicious activity on your site.

bottom of page