How to protect your users from automated attacks

Let’s explore the best ways to protect your users from the rapidly evolving menace of automated attacks.

 min. read
Last updated:
July 14, 2023

Gartner projects that by 2025, cyber attackers will have fully weaponized operational technology (OT) environments to cause critical harm to human users.  Consequently, enterprises must do more to protect their users from automated attacks to prevent the devastation they can bring. Let’s explore the best ways to protect your users from the rapidly evolving menace of automated attacks.

What are Automated Attacks?

An automated attack or threat is one that uses sophisticated tools like bots to maliciously perform large amounts of repetitive tasks like password spraying with hardly any cost. For instance, an automated attack can utilize malicious bots to exploit vulnerabilities in your web application. Hackers can use bots like this to carry out DDoS attacks on your application and eventually crash your site.

Common Types of Automated Attacks

There are numerous ways in which a cyber attacker can apply automation when compromising your user accounts. However, here are the most frequently used automated attack types.


Malicious bots are at the heart of automated attacks. Hackers use them to run automated tasks like data indexing and even attack execution. Automated bot attacks are also increasingly becoming the tool of choice for hackers looking to launch sophisticated attacks. For instance, within the first half of 2020, 442 million automated bot attacks were generated in North America alone, making it a significant threat.

Brute Force

Traditionally, brute force attacks refer to one that repeatedly tests multiple passwords from sources like a dictionary against a single account. Beyond passwords, hackers have been known to use brute force to guess encryption keys or uncover hidden web pages. While this trial and error may seem slow and ineffective, hackers can speed things up by repeatedly using bots to test the passwords or login info.

Credential Stuffing

Credential stuffing relies on the idea that many users typically reuse their passwords. It involves testing already compromised login credentials like username/password pairs obtained from another data breach. Credential stuffing is more potent because attackers can use bots to automate and scale their attacks. Click here to see some password reset best practices.

Password Spraying

This is another type of brute force attack. In a Password spraying automated attack, the hacker essentially tests a single (usually weak) password against many accounts on your application. For instance, an attacker could brute force your logins by using a default password (like Password@123) against multiple users on your application. This means they’re more likely to bypass account lockouts since they’re trying the same password on many different user accounts. Read on as we explore best practices for mitigating automated attacks based on the OWASP cheatsheet.

Stay Ahead of Cyberattacks with Authgear

Add user authentication and other security features to your apps

Get Demo

Best Practices for Mitigating Automated Attacks

If you’re looking to protect your users from automated attacks, there are effective mechanisms you can implement across your organization. The following best practices can effectively help mitigate automated attacks in your organization.

Multi-factor Authentication (MFA)

Multi-factor authentication (MFA) plays an essential role in protecting your users from automated attacks. This authentication best practice effectively adds a layer of protection to access your applications, making it even more difficult for automated attacks to bypass. Analysis by Microsoft suggests that MFA could have stopped 99.99% of user account compromises. The OWASP cheatsheet for authentication recommends that MFA be implemented wherever possible.

Account Lockout

To a large extent, this authentication security mechanism is the most common one you can adopt for protecting your users from automated attacks. An account lockout mechanism prevents additional logins after a specific number of failed login attempts. This mechanism is effective as it locks out your user accounts rather than an attacker's source IP address. So, if an automated attack attempts to use a large number of IP addresses, the account will lockout after several failed login attempts. There are three key factors to consider when implementing an account lockout mechanism.

  • Lockout threshold: This refers to the maximum number of failed login attempts before an account must be locked out.
  • Observation window: The specific timeframe that the suspicion login attempts must occur within.
  • Lockout duration: The duration the account will be locked out.

When implementing an account lockout mechanism, you’ll need to ensure that an attacker can’t use it to effect a denial of service attack. One way to prevent this is to allow your users to reset their passwords even when an account is locked out.


Implementing a CAPTCHA can help you prevent automated login attempts on your user accounts. However, some automated attackers can exploit weaknesses in many CAPTCHA implementations. As a result, you cannot entirely rely on a CAPTCHA for preventing automated attacks. At best, they’re great for making automated login attempts on your user accounts more time-consuming rather than preventing them.


Since cyber attackers are not in the business of giving notice before an attack, you’ll need to log and monitor all authentication activity across your application or network. Logging and monitoring essentially allow you to ensure that all password failures and account lockouts are logged and reviewed in real-time.

Passwordless Login

Although authentication via usernames and passwords alongside MFA is secure, there are situations where this conventional protocol just isn’t feasible. For instance, if a third-party app needs to connect to your web application via a mobile device, it would be unsafe to allow it to store a username and password combination. In this case, a passwordless authentication protocol is recommended as it potentially limits access and attack surfaces to your application.

Design your app to be password manager friendly

With 60% of passwords being reused across multiple accounts globally, you’re inadvertently at the mercy of credential stuffing and password spraying attacks. However, password managers can help your users create and securely store very complex passwords. By designing your application to be password manager friendly, you’d be protecting them from automated attacks.

Closing Thoughts

With a wide range of tools and resources at the disposal of hackers, businesses must remain ahead in the quest to prevent attacks. Protecting your users from automated cyberattacks isn’t a one-off process. It requires continuous finetuning and awareness.  

Authgear offers a Plug-and-play authentication and user management solution that allows you to seamlessly add user authentication and many other security features to your applications. These features like passwordless authentication, social logins, and 2FA can ultimately help to protect your users from automated attacks. Interested in Authgear? Let’s talk.


Privacy is important to us, so you have the option of disabling certain types of storage that may not be necessary for the basic functioning of the website. Blocking categories may impact your experience on the website.

Accept all cookies

These items are required to enable basic website functionality.

Always active

These items are used to deliver advertising that is more relevant to you and your interests.

These items allow the website to remember choices you make (such as your user name, language, or the region you are in) and provide enhanced, more personal features.

These items help the website operator understand how its website performs, how visitors interact with the site, and whether there may be technical issues.

Thank you! Your submission has been received!
Oops! Something went wrong while submitting the form.