Table of Contents
Reply content:
Home Backend Development PHP Tutorial How to prevent denial of service attacks in APIs written in PHP?

How to prevent denial of service attacks in APIs written in PHP?

Jul 21, 2016 pm 12:01 PM
android ios key php websocket

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
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
Two Point Museum: All Exhibits And Where To Find Them
1 months ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

PHP 8.4 Installation and Upgrade guide for Ubuntu and Debian PHP 8.4 Installation and Upgrade guide for Ubuntu and Debian Dec 24, 2024 pm 04:42 PM

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

How To Set Up Visual Studio Code (VS Code) for PHP Development How To Set Up Visual Studio Code (VS Code) for PHP Development Dec 20, 2024 am 11:31 AM

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

Xiaomi Redmi Note 14 Pro Plus arrives as first Qualcomm Snapdragon 7s Gen 3 smartphone with Light Hunter 800 camera Xiaomi Redmi Note 14 Pro Plus arrives as first Qualcomm Snapdragon 7s Gen 3 smartphone with Light Hunter 800 camera Sep 27, 2024 am 06:23 AM

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

How do you parse and process HTML/XML in PHP? How do you parse and process HTML/XML in PHP? Feb 07, 2025 am 11:57 AM

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

Oppo Find X8 design looks like a cross between Apple iPhone 16 Pro and OnePlus Open in early images Oppo Find X8 design looks like a cross between Apple iPhone 16 Pro and OnePlus Open in early images Sep 28, 2024 am 06:04 AM

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

PHP Program to Count Vowels in a String PHP Program to Count Vowels in a String Feb 07, 2025 pm 12:12 PM

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

iQOO Z9 Turbo+ debuts as Dimensity 9300+ smartphone with \'off-the-charts\' battery life iQOO Z9 Turbo+ debuts as Dimensity 9300+ smartphone with \'off-the-charts\' battery life Sep 26, 2024 am 06:20 AM

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

Samsung Galaxy Z Fold Special Edition revealed to land in late October as conflicting name emerges Samsung Galaxy Z Fold Special Edition revealed to land in late October as conflicting name emerges Oct 01, 2024 am 06:21 AM

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

See all articles