


How to prevent denial of service attacks in APIs written in PHP?
Many companies now use PHP to write APIs to connect to the front-end web/iOS/Android. The cloud and end are completely separated, and dynamic negotiation cannot be achieved. If both parties agree on a static KEY, it will be transparent in the js of the web. Even ios/android can easily obtain this KEY through package interception or decompilation.
Nowadays, the maximum concurrency that general cloud services can accept is only a few thousand. If it is full by a denial of service attack, it will inevitably affect the access of normal users. Especially when using a communication protocol like websocket, once a connection is established, it will always be in trouble. If you just write a simple multi-line simulated connection to harass it, the server will basically fail.
How to properly prevent such attacks on the PHP side? There is no need to go too extreme. Controlling the paralysis within 10 minutes should still be acceptable for ordinary small applications.
Reply content:
In fact, the problem mentioned by the question is widespread. It can be said from two aspects:Code aspect:
Programmer’s experience. Generally, it is the black and white list in terms of code, followed by the handling of interface timeout, and the rest are some specifications. In fact, there is no particularly good experience. More generally, ordinary hackers will not DDOS you directly. If it were a real DDOS, these would be enough for you. It is more about daily maintenance and handling of data anomalies.
Actually, you don’t have to worry about being maliciously attacked. To put it bluntly, the interface is also POST GET. As long as you filter the interface data to ensure the security of the data, common vulnerabilities can be prevented. Ordinary third-rate hackers will basically block this door. Unless your website is very famous, you can find a security company to do a test. Basically OK To deal with DDoS attacks, it is more about system-level protection. The API interface written by PHP is generally for business. What PHP for business can do is not to hang up and respond as quickly as possible
In addition, the machine load capacity should be taken into consideration , basically this kind of problem requires the use of flow control to limit the number of times a terminal can access a certain API within a period of time. 1. The authentication interface receives a client time and a signature. First verify that the client time and server time are within a certain error range (such as ±5 minutes, the larger the error range, the less secure), and then verify whether the signature is consistent (the signature algorithm must use the client time). After success, a token and a random string.
2. All interfaces except the authentication interface must receive token and a signature. First check whether the token is legal, and then verify whether the signature is consistent (the signature algorithm must use the random string returned by the authentication interface).
3. Strategies for all interfaces:
1) If the signature verification fails a certain number of times (1 time, 2 times, 3 times, the larger the number, the less secure), the IP will be blocked.
2) If a single IP call exceeds the limit (it is best to set different restrictions for each interface according to business needs. For example, you can request 5 times/day for login), block the IP. ip whitelist If it happens too often, the IP will be blocked. Don’t go to such trouble, use iptables

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

PHP 8.4 brings several new features, security improvements, and performance improvements with healthy amounts of feature deprecations and removals. This guide explains how to install PHP 8.4 or upgrade to PHP 8.4 on Ubuntu, Debian, or their derivati

Visual Studio Code, also known as VS Code, is a free source code editor — or integrated development environment (IDE) — available for all major operating systems. With a large collection of extensions for many programming languages, VS Code can be c

The Redmi Note 14 Pro Plus is now official as a direct successor to last year'sRedmi Note 13 Pro Plus(curr. $375 on Amazon). As expected, the Redmi Note 14 Pro Plus heads up the Redmi Note 14 series alongside theRedmi Note 14and Redmi Note 14 Pro. Li

This tutorial demonstrates how to efficiently process XML documents using PHP. XML (eXtensible Markup Language) is a versatile text-based markup language designed for both human readability and machine parsing. It's commonly used for data storage an

Historically, Oppo has refreshed its flagship 'Find X' series in late winter or early spring, save for the original Find X that it announced in June 2018. To that end, the Find X7 and Find X7 Ultra are barely more than six months old at this point. H

A string is a sequence of characters, including letters, numbers, and symbols. This tutorial will learn how to calculate the number of vowels in a given string in PHP using different methods. The vowels in English are a, e, i, o, u, and they can be uppercase or lowercase. What is a vowel? Vowels are alphabetic characters that represent a specific pronunciation. There are five vowels in English, including uppercase and lowercase: a, e, i, o, u Example 1 Input: String = "Tutorialspoint" Output: 6 explain The vowels in the string "Tutorialspoint" are u, o, i, a, o, i. There are 6 yuan in total

TheZ9 Turbo+has now been unleashed on Vivo's online Chinese store at 2,199 yuan (~$313) for a 12GB RAM/256GB internal storage base model, whereas theRedmiK70 Extreme Editionstarted at 2,599 yuan (~$370) with the same configuration: in fact, its newiQ

The launch of Samsung's long-awaited 'Special Edition' foldable has taken another twist. In recent weeks, rumours about the so-called Galaxy Z Fold Special Edition went rather quiet. Instead, the focus has shifted to the Galaxy S25 series, including
