The present disclosure generally relates to the field of computer network security technology and, more particularly, relates to a method and apparatus for defending an HTTP flood attack.
The Hypertext Transfer Protocol flood (HTTP flood) attack is a method mainly used for attacking servers. Currently, the method for defending an HTTP flood attack is to set a protection device between a client terminal and a server. After the client terminal establishes a Transmission Control Protocol (TCP) connection with the server, the client terminal may transmit an HTTP request to the server. After obtaining the HTTP request, the protection device uses a preset protection strategy to verify the HTTP request, and transmits the HTTP request to the server after the verification is passed. If the verification is not passed, the protection device intercepts the HTTP request to prevent the attacker from transmitting the HTTP request to attack the server.
With the evolution of attack and defense confrontation, the attack programs configured on some attackers are already able to analyze the general protection strategies, so as to break through some simple protection strategies. At the same time, some attackers may also analyze the attack outcome during the attack. When the outcome is not desirable, an attacker may enhance the attack intensity and attack type, so as to break through the present protection strategy.
In general, a protection strategy needs to be configured in advance. For a configuration administrator, because the attack intensity and attack type cannot be predicted, a pre-configured protection strategy may be either too loose, resulting in a poor protection outcome, or too strict, which then affects normal user requests. When facing attacks with different intensities and different types, the operation and maintenance personnel need to adjust the strategy for different attack modes, and thus the timeliness is very poor and the effective protection strategies may be not issued in time, resulting in interrupted service due to the attacks. Additionally, in the protection process, the operation and maintenance personnel may not evaluate whether the protection strategy used for the present attack is effective or not. Accordingly, the personnel need to pay very close attention to the attack and defense states and the impact on the requests from normal users, and thus the operation and maintenance are really challenging.
To solve the problems in the existing technologies, the embodiments of the present disclosure provide a method and apparatus for defending an HTTP flood attack. The technical solutions are as follows:
In one aspect, a method for defending an HTTP flood attack is provided. The method includes:
when a first protection strategy is used for protection, detecting a protection performance of the first protection strategy; and
when the protection performance of the first protection strategy does not meet requirements, using a second protection strategy for protection, where a protection level of the second protection strategy is higher than a protection level of the first protection strategy.
Optionally, detecting the protection performance of the first protection strategy includes:
collecting the number of HTTP requests transmitted to a server within a predetermined time interval, and when the number of HTTP requests transmitted to the server is greater than a first threshold, determining that the protection performance of the first protection strategy does not meet the requirements.
Optionally, detecting the protection performance of the first protection strategy includes:
collecting a traffic volume of HTTP requests transmitted to a server within a predetermined time interval, and when the traffic volume of HTTP requests transmitted to the server is greater than a preset traffic volume, determining that the protection performance of the first protection strategy does not meet the requirements.
Optionally, detecting the protection performance of the first protection strategy includes:
transmitting detection information to a server according to a preset cycle, and when no response information, transmitted by the server based on the detection information, is received within a preset time period, determining that the protection performance of the first protection strategy does not meet the requirements.
Optionally, the detection information is preset detection information, and after transmitting the detection information to the server according to the preset cycle, the method further includes:
when the server is in a service state, acquiring, by the server, pre-stored response information after receiving the preset detection information; and
transmitting, by the server, the response information to the protection device.
Optionally, transmitting the detection information to the server according to the preset cycle further includes:
replacing a source address in a target HTTP request with an IP address of the protection device according to the preset cycle to obtain detection information including the IP address of the protection device, where the target HTTP request is one of verified requests among HTTP requests transmitted by client terminals; and
transmitting the detection information to the server.
Optionally, after transmitting the detection information to the server, the method includes:
when response information, transmitted by the server based on the detection information, is received, replacing a target address in the response information with the source address in the target HTTP request; and
transmitting the response information with the target address having been replaced.
Optionally, the method further includes:
collecting the number of HTTP requests received within each predetermined time interval;
when the number of HTTP requests received within the predetermined time interval is greater than a second threshold, using the first protection strategy for protection; and
when each number of HTTP requests received within a preset number of successive predetermined time intervals is not greater than the second threshold, stopping the protection.
In another aspect, an apparatus for defending an HTTP flood attack is provided. The apparatus includes:
a detection unit that is configured to, when a first protection strategy is used for protection, detect a protection performance of the first protection strategy; and
a protection unit that is configured to, when the protection performance of the first protection strategy does not meet requirements, use a second protection strategy for protection, where a protection level of the second protection strategy is higher than a protection level of the first protection strategy.
Optionally, the detection unit is specifically configured to collect the number of HTTP requests transmitted to a server within a predetermined time interval; and
the protection unit is specifically configured to, when the number of HTTP requests transmitted to the server is greater than a first threshold, determine that the protection performance of the first protection strategy does not meet the requirements.
Optionally, the detection unit is further configured to collect a traffic volume of HTTP requests transmitted to a server within a predetermined time interval; and
the protection unit is further configured to, when the traffic volume of HTTP requests transmitted to the server is greater than a preset traffic volume, determine that the protection performance of the first protection strategy does not meet the requirements.
Optionally, the detection unit is further configured to transmit detection information to a server according to a preset cycle; and
the protection unit is further configured to, when no response information, transmitted by the server based on the detection information, is received within a preset time period, determine that the protection performance of the first protection strategy does not meet the requirements.
Optionally, the detection information is preset detection information; and
the detection unit is further configured to, when the server is in a service state, receive pre-stored response information transmitted by the server based on the preset detection information.
Optionally, the detection unit is further configured to: replace a source address in a target HTTP request with an IP address of a protection device according to the preset cycle to obtain detection information including the IP address of the protection device, where the target HTTP request is one of verified requests among HTTP requests transmitted by client terminals; and transmit the detection information including the IP address of the protection device to the server.
Optionally, the detection unit is further configured to: when response information, transmitted by the server based on the detection information, is received, replace a target address in the response information with the source address in the target HTTP request; and transmit the response information with the target address having been replaced.
Optionally, the protection unit is further configured to: collect the number of HTTP requests received within each predetermined time interval; when the number of HTTP requests received within the predetermined time interval is greater than a second threshold, use the first protection strategy for protection; and when each number of HTTP requests received within a preset number of successive predetermined time intervals is not greater than the second threshold, stop the protection.
In another aspect, a protection device is provided. The protection device includes a processor and a memory that stores at least one instruction, at least one program, a code set, or an instruction set. The at least one instruction, at least one program, a code set, or an instruction set is loaded and executed by the processor to implement the above-described defending methods.
The methods and apparatuses for defending an HTTP flood attack provided by the embodiments of the present disclosure may automatically detect the attack mode and the protection outcome, and automatically adjust the used protection strategy in response to different attack modes, which not only improves the protection outcome, but also greatly reduces the impact on the normal use of users, while the timeliness is also good.
To make the technical solutions in the embodiments of the present disclosure clearer, a brief introduction of the accompanying drawings consistent with descriptions of the embodiments will be provided hereinafter. It is to be understood that the following described drawings are merely some embodiments of the present disclosure. Based on the accompanying drawings and without creative efforts, persons of ordinary skill in the art may derive other drawings.
To make the objective, technical solutions, and advantages of the present disclosure clearer, the present disclosure will be made in detail hereinafter with reference to the accompanying drawings.
The embodiments of the present disclosure provide a method for defending an HTTP flood attack, which may be applied to a system architecture shown in
When there is no attack, the protection device may not enforce protection. That is, after receiving an HTTP request, the protection device does not need to verify the security of the HTTP request, but transmits the HTTP request directly to the server. The process of determining whether an attack exists or not by the protection device includes determining the number of HTTP requests received within each predetermined time interval (e.g., 5 seconds). When the number of HTTP requests received within any predetermined time interval exceeds a threshold, i.e., a second threshold, it may be considered that an attack exists. If the number of HTTP requests received within a predetermined time interval does not exceed the threshold, it may be considered that there is no attack. It should be noted that each predetermined time interval may be continuous in time, that is, the end time of the last predetermined time interval is the start time of the next predetermined time interval. Or each predetermined time interval may also be not continuous in time.
When there is an attack, the protective device starts to enforce the protection. The process of enforcing the protection by the protection device includes: the protection device receives an HTTP request transmitted by the client terminal, parses the received HTTP request, and transmits the data for acquiring the verification information to the client terminal when the HTTP request does not include the verification information; after receiving the data, the client terminal acquires the verification information corresponding to the data, and re-transmits an HTTP request containing the verification information to the protection device; after receiving the HTTP request, the protection device parses the verification information in the HTTP request and performs verification; when the verification is passed, the HTTP request is transmitted to the server. When attacking a server, an attacker is generally only in charge of transmitting a large number of HTTP requests, but does not receive the verification information transmitted by the protection device or does not parse the verification information after receiving it. Therefore, the attacker may not transmit a new HTTP request that includes the verification information. An HTTP request that does not pass the verification by the protection device is considered to be a malicious request transmitted by an attacker, which will be discarded and will not be forwarded to the server. An HTTP request verified by the protection device is considered to be a normal request and will be forwarded to the server through the protection device. Therefore, the protection device may intercept an HTTP request transmitted by an attacker, thereby preventing the malicious request of the attacker from affecting the server.
The protection device stores a protection strategy set, where the protection strategy set includes at least two protection levels of protection strategies, for example, a 302-redirect verification protection strategy, a JavaScript script verification protection strategy, or a picture verification protection strategy. In a specific implementation, the protection strategies may be classified into different levels according to the levels of difficulty of attackers in cracking the protection strategies. For example, for the 302-redirect verification protection strategy, the data transmitted by the protection device includes the verification information, so the verification information may be acquired directly from the data. For the JavaScript script verification protection strategy, a corresponding calculation needs to be performed according to the program(s) in the script to generate the verification information, and thus an attacker is less likely to crack the JavaScript script verification protection strategy. The protection level of the JavaScript script verification protection strategy is higher than the protection level of the 302-redirect verification protection strategy. For the picture verification protection strategy, a user needs to input the verification information according to the picture, and the protection level is even higher.
When entering the protection state from an unprotected state, the protection device may enforce the protection by using a default protection strategy, such as a protection strategy with the lowest protection level. When such protection strategy is used for protection, the server may be still under attack, then a protection strategy higher than the existing protection level may be used. A description for this process will be made in detail hereinafter.
Step 201: When a first protection strategy is used for protection, detecting the protection performance of the first protection strategy.
The first protection strategy may be any protection strategy in the protection strategy set.
Step 202: When the protection performance of the first protection strategy does not meet the requirements, using a second protection strategy for protection, where the protection level of the second protection strategy is higher than the protection level of the first protection strategy.
When there is an attack, that is, when the protection device beings to enforce the protection, the protection device may detect the protection performance, or the protection outcome, of the first protection strategy currently used. When the protection performance of the first protection strategy does not meet the requirements, a protection strategy with a higher level of protection is used instead, resulting in an automatic adjustment of the protection strategy.
The embodiments of the present disclosure provide two modes to detect the protection performance of the first protection strategy.
Detection Mode 1: Collecting the number or the traffic volume of HTTP requests transmitted to the server within a predetermined time interval.
When an attacker attacks the server, the attacker transmits a large number of malicious requests. When the currently used protection strategy has a poor protection performance against the present malicious attack, the malicious requests may be not detected and mistakenly considered as legitimate HTTP requests, and thus a large number of malicious requests are forwarded to the server. Accordingly, when it is detected that the number of HTTP requests transmitted to the server within a predetermined time interval is greater than a first threshold, or the traffic volume of HTTP requests transmitted to the server is greater than a preset traffic volume, it may be determined that the protection performance of the currently used protection strategy is poor, and the requirements are not met. At this point, a protection strategy with a protection level higher than the currently used protection strategy may be needed for the protection.
Detection Mode 2: Transmitting detection information to the server according to a preset cycle; and when no response information, transmitted by the server based on the detection information, is received within a preset time period, determining that the protection performance of the first protection strategy does not meet the requirements.
In a specific implementation, the protection device may enforce the protection by using the Detection Mode 1 and the Detection Mode 2 simultaneously, or by using only one of the two detection modes.
In the embodiments of the present disclosure, the protection strategy being used may be upgraded multiple times. That is, the protection strategy may be upgraded whenever the protection performance of the currently used protection strategy is found not to meet the requirements. For instance, the currently used protection strategy is the 302-redirect verification protection strategy. After the upgrade, the JavaScript script verification protection strategy may be used. Once the server is found to still under the attack after the enforcement of the JavaScript script verification protection strategy, another upgrade may be conducted and the image verification protection strategy is used instead. Each protection strategy in the protection strategy set may be ordered according to the levels of protection. When upgrading a protection strategy, another protection strategy that is one level higher than the present protection strategy may be used. If the present protection strategy is at the highest protection level, the service state of the server may be further detected. When the server is detected to be not in the service state, it means that the protection strategy with the highest protection level may not protect the present attack, then the protection levels of the protection strategies may be further enhanced.
When the protection device enforces the protection, the number of HTTP requests received in each predetermined time interval may be collected. When each number of HTTP requests received within a preset number of successive predetermined time intervals is not greater than the second threshold, it means that there is no attack anymore and the protection may be stopped. In the embodiments of the present disclosure, the first threshold and the second threshold may be the same or different, which is not specifically limited herein.
The Detection Mode 2 will be made in detail hereinafter.
Step 301: The protection device uses the first protection strategy for protection, and transmits detection information to the server according to a preset cycle.
When there is an attack, that is, when the protection device starts to enforce the protection, the protection device may transmit the detection information to the server according to a preset cycle, to detect whether the server is in the service state, and determine the protection outcome of the present protection strategy against the present attack based on the service state of the server. When the protection device is in the protection state, the service state of the server may be continuously monitored until the protection is stopped.
Step 302: When no response information, transmitted by the server based on the detection information, is received within a preset time period, the protection device uses a second protection strategy for protection, where the protection level of the second protection strategy is higher than the protection level of the first protection strategy.
When the server is in the service state, the server may receive the detection information transmitted by the protection device, and transmit response information to the protection device according to the detection information. When the server is attacked and not in the service state, the server may not receive the detection information transmitted by the protection device, or may not transmit the response information to the protection device according to the detection information, and thus the protection device may not receive the response information. The situation when the protection device does not receive the response information includes the situation when no information is received and the situation when the information is received with a notified error.
The protection device may use two implementations to transmit the detection information to the server, which will be illustrated below separately.
Implementation 1
The protection device transmits preset detection information to the server according to a preset cycle. That is, the detection information transmitted by the protection device is the same every time. The preset detection information may be a complete HTTP request, or include only the request header of an HTTP request. The format of the detection information is not specifically limited herein, as long as the used detection information is able to be identified by the server. The server pre-stores response information corresponding to the detection information. That is, the detection information corresponds to a fixed page, and a fixed domain name may be used to access the page.
When the server is in the service state, the server acquires the pre-stored response information after receiving the preset detection information, and then transmits the response information to the protection device. After receiving the response information, the protection device may determine that the server is in a normal service state. When no response information, transmitted by the server based on the detection information, is received within a preset time period, it may be determined that the server is not in the service state. The present protection strategy may be then upgraded to a higher-level protection strategy.
It should be noted that the server may not pre-store the response information corresponding to the detection information, and the detection information may be a complete HTTP request. The server may perform a normal response service based on the HTTP request, and then transmit the response information to the protection device. The response service is similar to a response service based on an HTTP request transmitted by the client terminal.
Implementation 2
The protection device replaces the source address in a target HTTP request with the Internet Protocol (IP) address of the protection device according to a preset cycle, and uses the HTTP request containing the IP address of the protection device as the detection information, where the target HTTP request may be any verified request among the HTTP requests transmitted by the client terminals. The protection device then transmits the detection information to the server. The server may perform a normal response service according to the HTTP request and transmit the response information to the protection device. When the response information transmitted by the server based on the detection information is received, it indicates that the server is in the service state. The protection device replaces the target address in the response information with the source address in the target HTTP request, and transmits the response information with the target address having been replaced.
In the disclosed implementation, the HTTP request transmitted by the client terminal is used as the detection information after the replacement of the source address, which allows the server to transmit the response information to the protection device according to the detection information. After receiving the response information, the protection device replaces the target address, to allow the client terminal to receive the response information. This may not only detect whether the server is in the service state, but also does not affect the normal access of the client terminal, and also does not increase the burden on the server caused by periodically transmitting additional detection information.
The methods for defending an HTTP flood attack provided by the embodiments of the present disclosure may automatically detect the attack mode and the protection outcome, and may automatically adjust the used protection strategy in response to different attack modes. That is, by default, a protection strategy with a relatively low protection level is used for protection. When the present protection strategy is detected to be insufficient to protect the present attack and consequently the protection outcome is undesirable, the present protection strategy may be automatically upgraded to a higher-level protection strategy until the upgraded protection strategy may protect the present attack. In this way, the protection outcome may be improved, and the impact on the normal use of users may be greatly reduced, while the timeliness is also good.
The detection unit 401 is configured to detect the protection performance of the first protection strategy when the first protection strategy is used for protection.
The protection unit 402 is configured to use a second protection strategy for protection when the protection performance of the first protection strategy does not meet the requirements, where the protection level of the second protection strategy is higher than the protection level of the first protection strategy.
Preferably, the detection unit 401 is specifically configured to collect the number of HTTP requests transmitted to the server within a predetermined time interval; and the protection unit 402 is specifically configured to, when the number of HTTP requests transmitted to the server is greater than the first threshold, determine that the protection performance of the first protection strategy does not meet the requirements.
Preferably, the detection unit 401 is further configured to collect the traffic volume of the HTTP requests transmitted to the server within a predetermined time interval; and the protection unit 402 is further configured to, when the traffic volume of the HTTP requests transmitted to the server is greater than a preset traffic volume, determine that the protection performance of the first protection strategy does not meet the requirements.
Preferably, the detection unit 401 is further configured to transmit detection information to the server according to a preset cycle; and the protection unit 402 is further configured to, when no response information, transmitted by the server based on the detection information, is received within a preset time period, determine that the protection performance of the first protection strategy does not meet the requirements.
Preferably, the detection information is preset detection information; and the detection unit 401 is further configured to, when the server is in a service state, receive pre-stored response information transmitted by the server based on the preset detection information.
Preferably, the detection unit 401 is further configured to: replace the source address in a target HTTP request with the IP address of the protection device according to the preset cycle to obtain detection information including the IP address of the protection device, where the target HTTP request is any one of verified requests among HTTP requests transmitted by client terminals; and transmit the detection information to the server.
Preferably, the detection unit 401 is further configured to: when the response information transmitted by the server based on the detection information is received, replace the target address in the response information with the source address in the target HTTP request; and transmit the response information with the target address having been replaced.
Preferably, the protection unit 402 is further configured to: collect the number of HTTP requests received within each predetermined time interval; and when each number of HTTP requests received within a preset number of successive predetermined time intervals is not greater than a second threshold, stop the protection.
Preferably, the protection unit 402 is further configured to: collect the number of HTTP requests received within a predetermined time interval; and when the number of HTTP requests received within the predetermined time interval is greater than the second threshold, use the first protection strategy for protection.
The apparatuses for defending an HTTP flood attack provided by the embodiments of the present disclosure may automatically detect the attack mode and the protection outcome, and automatically adjust the used protection strategy in response to different attack modes, which not only improves the protection outcome, but also greatly reduces the impact on the normal use of users, while the timeliness is also good.
It should be noted that, when enforcing the protection, an apparatus for defending an HTTP flood attack provided by the above embodiments is illustrated merely by way of example of the foregoing division of the functional modules. In real applications, the foregoing functions may be allocated into and implemented by different functional modules according to the needs. That is, the internal structure of the apparatus may be divided into different functional modules to complete all or part of the above-described functions. In addition, the apparatuses for defending an HTTP flood attack and the methods for defending an HTTP flood attack provided by the foregoing embodiments are attributed to the same concept. Accordingly, for the specific implementation process of the apparatuses, the embodiments for the methods may be referred to, details of which will not be described again here.
The protection device 500 may further include one or more power sources 529, one or more wired or wireless network interfaces 550, one or more input and output interfaces 558, one or more keyboards 554, and/or one or more operating systems 541, such as Windows Server™, Mac OS X™, Unix™, Linux™, FreeBSD™, and the like.
The protection device 500 may include a memory and one or more programs, where the one or more programs are stored in the memory and configured to be executed by one or more processors to implement the one or more programs that include instructions configured to perform the defending methods described above.
A person skilled in the art may understand that all or part of the steps of the above embodiments may take the form of hardware implementation or the form of implementation of programs for instructing relevant hardware. The programs may be stored in a computer-readable storage medium. The storage medium may be a read-only memory, a magnetic disk, or an optical disk, etc.
Although the present disclosure has been described as above with reference to preferred embodiments, these embodiments are not constructed as limiting the present disclosure. Any modifications, equivalent replacements, and improvements made without departing from the spirit and principle of the present disclosure shall fall within the scope of the protection of the present disclosure.
Number | Date | Country | Kind |
---|---|---|---|
2018106314867 | Jun 2018 | CN | national |
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/CN2018/095433 | 7/12/2018 | WO | 00 |