If your site needs to customize the user access policy, such as prohibiting users from specified regions, allowing specified external sites to link to the site content, and allowing only specified users to access certain resources. Custom rules support matching client requests based on single rule matching conditions or multiple matching conditions. By allowing, intercepting, redirecting, and returning custom pages, you can control the request strategy of matched requests, which can help your site more flexibly limit the content that users can access.
Typical Scenarios and Usage
You can choose the appropriate rule type to protect your site according to different scenarios. Custom rules are divided into the following types:
Basic access control: Supports single condition matching requests, disposes or observes matched requests, and is suitable for simple scenario protection, such as configuring IP blocklist/allowlist, Referer blocklist, UA blocklist/allowlist, or regional restrictions.
Precise matching rules: Supports multiple condition combination matching requests, disposes or observes matched requests, and is suitable for complex scenario protection configuration, such as allowing only specified users to access files under specified paths.
Managed custom policy: A policy customized by Tencent security experts, which does not support console adjustment. For details, please see: Managed custom rules.
Note:
When there are multiple rules of the same type, the priority of the rules is as follows:
1. Rules within Basic access control: when a request matches multiple rules, the actions will be executed in the following order: Observe > Block.
2. Precise matching rules will be executed from high to low priority (Priority Value from small to large);
Example Scenario 1: Only allow access from specific countries/regions
To comply with the legal requirements of specified business regions, if the current business only allows access from non-Chinese mainland regions, you may need to restrict the visitor's source region. For such scenarios, you can use the regional control rules in basic access control to achieve this. The operation steps are as follows:
1. Log in to the Tencent Cloud EdgeOne console, enter Service Overview in the left menu bar, and click the site to be configured under Website Security Acceleration.
2. Click Security > Web Security . By default, it is a site-level security policy. To configure differentiated security policies for a specific domain name under the current site, you can enter the Domain-level security policy tab and then click the corresponding domain name to enter the configuration page for the domain-level security policy. The subsequent steps are the same.
3. Locate the Custom rules tab and click Add rule in Basic access control .
4. Enter the rule name and configure the control type, matching method, and control range. In this example scenario, you can set the control type to Region Control , select the matching method as Include and the matching content as Chinese mainland (All) , and set the action to Block .
5. Click Save . The rule will be deployed and take effect. At this time, if the client access IP is from the Chinese mainland, the access to the website is denied.
Example Scenario 2: Configure Referer to control external site access
Note:
The HTTP protocol allows the Referer header to use a full URL or partial URL. You should configure the matching content according to the actual situation. For details about the Referer header, see RFC 9110.
To prevent unauthorized sites from accessing resources through links, you can use Referer control rules in basic access control to block requests from unauthorized sources. For example, if the service at the https://www.myexample.com site needs to allow access requests through the advertising partner's link https://ads.example.com/ads-link and reject access through other site links, you can take the following steps:
1. Log in to the Tencent Cloud EdgeOne console, enter Service Overview in the left menu bar, and click the site to be configured under Website Security Acceleration.
2. Click Security > Web Security . By default, it is a site-level security policy. Click the Domain-level security policy tab and then click the target domain name such as www.myexample.com , to enter the configuration page for the security policy of the target domain name.
3. Locate the Custom rules tab and click Add rule in Basic access control.
4. Enter the rule name and configure the control type, matching method, and control range. In this example scenario, you can set the control type to Referer control , and select the action as Block when the request Referer does not equal https://www.myexample.com* or https://ads.example.com/ads-link*.
5. Click Save. The rule will be deployed and take effect.
Scenario Example 3: Configure URL Access Restriction
When sensitive directories or resources exist in the currently connected business, you can use the URL control rule in basic access control to block unauthorized access. For example, forbid external access to the /admin/* or /config/*.json directories. Directions:
1. Log in to the Tencent Cloud EdgeOne console, enter Service Overview in the left menu bar, and click the site to be configured under Website Security Acceleration.
2. Click Security > Web Security. By default, the site-level security policy is applied. Click the Domain-level Security Policy Tab, then select the Target Domain Name to enter the Protection Policy Configuration Interface, such as www.myexample.com.
3. Locate the Custom Rule card, click Add Rule in Basic Access Control.
4. Fill in the rule name, configure the control type, match mode, and control scope. Take the scenario example: the control type is URL control. When the request URL matches the wildcard /admin/* or /config/*.json, the handling method is block. Among them:
Use * to match zero or multiple characters, use ? to match a single character.
https://www.myexample.com* can match request sources such as https://www.myexample.com, https://www.myexample.com/, https://www.myexample.com/index.html, and https://www.myexample.com/news?id=1.
https://ads.example.com/ads-link* can match request sources such as https://ads.example.com/ads-link, https://ads.example.com/ads-link/, and https://ads.example.com/ads-link?campaign=123.
5. Click Save. The rule will deploy.
Scenario Example 4: Configure IP Blocklist
When identifying suspicious anomalies in metric analysis or Web security analysis, you can use the client IP control rule in basic access control to block access requests from abnormal client IPs. For example: forbid access from the subnet 2.2.2.0/24 and the single IP 1.1.1.1. Directions:
1. Log in to the Tencent Cloud EdgeOne console, enter Service Overview in the left menu bar, and click the site to be configured under Website Security Acceleration.
2. Click Security > Web Security. By default, the site-level security policy is applied. Click the Domain-level Security Policy Tab, then select the Target Domain Name to enter the Protection Policy Configuration Interface, such as www.myexample.com.
3. Locate the Custom Rule card, click Add Rule in Basic Access Control.
4. Fill in the rule name, configure the control type, match mode, and control scope. Take the scenario example: the control type is client IP control. When the client IP equals2.2.2.0/24 or 1.1.1.1, the handling method is block. Among them, the subnet 2.2.2.0/24 means all IPs from 2.2.2.0 to 2.2.2.255.
5. Click Save. The rule will deploy.
Scenario Example 5: Configure User-Agent Blocklist
When you locate suspicious anomalies in Metric Analysis or Web Security Analysis, you can use the User-Agent Control rule in Basic Access Control to block requests carrying abnormal User-Agents. For example: observing a large number of curl/ requests (such as curl/7.61.1, curl/8.7.1) and User-Agents from crawlers (such as Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; GPTBot/1.2; +https://openai.com/gptbot)) in the Top User-Agent metric analysis, which do not match normal business access methods and should be denied access. Directions:
1. Log in to the Tencent Cloud EdgeOne console, enter Service Overview in the left menu bar, and click the site to be configured under Website Security Acceleration.
2. Click Security > Web Security. By default, the site-level security policy is applied. Click the Domain-level Security Policy Tab, then select the Target Domain Name to enter the Protection Policy Configuration Interface, such as www.myexample.com.
3. Locate the Custom Rule card, click Add Rule in Basic Access Control.
4. Fill in the rule name, configure the control type, match mode, and control scope. Take the scenario example: the control type is User-Agent control. When the User-Agent matches the wildcard curl/* or *GPTBot*, the handling method is block. Among them:
Use * to match zero or multiple characters, use ? to match a single character.
curl/* matches curl/7.61.1, curl/8.7.1 and similar.
*GPTBot* matches any User-Agent containing the GPTBot flag, such as:
Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; GPTBot/1.2; +https://openai.com/gptbot)
GPTBot/1.0
CustomClient-GPTBot-Test
5. Click Save. The rule will deploy.
Precise Matching Rules
Example Scenario: Precisely control the exposure surface of sensitive resources on the site
If you need to control the exposure surface of sensitive resources (such as the background management page) on the site and only allow access from specific clients or specified networks. You can use the client IP matching and request URL matching combination in precise matching rules to achieve this.
For example, the current site domain name www.example.com has a management background login address path of /adminconfig/login, and this background is only allowed to be logged in by the specified client IP user 1.1.1.1. The operation steps are as follows:
1. Log in to the Tencent Cloud EdgeOne console, enter Service Overview in the left menu bar, and click the site to be configured under Website Security Acceleration.
2. Click Security > Web Security . By default, it is a site-level security policy. Click the Domain-level security policy tab and then click the target domain name such as www.example.com, to enter the configuration page for the security policy of the target domain name.
3. Locate the Custom rules tab and click Add rule in Precise matching rules .
4. On the rule adding page, select creating a blank rule, enter the rule name, and click Add.
5. Configure the judgment conditions and actions. In this example scenario, you can configure the matching fields as Request path (Path) equals /adminconfig/login and Client IP not matching 1.1.1.1 , and set the action to Block.
Note:
Priority: The lower the value, the higher the priority. When a request matches multiple rules, the action of the rule with the higher priority (lower numerical value) applies.
6. Click Save and publish . The rule will be deployed and take effect.
Related References
Supported Matching Condition Range
Custom rules can use matching conditions to control the scope of rule application. The following are the matching conditions supported by different custom rule types:
Basic access control
Rule type
Description
Client IP control
Control access requests based on client IP
Regional control
Control access requests based on client IP location
Referer control
Control access requests based on the Referer header content
User-Agent control
Control access requests based on the User-Agent
ASN control
Control access requests based on the client IP location ASN
URL control
Control access requests based on the request URL, supporting wildcard matching
Precise matching rules
Precise matching rules support the following matching conditions, and the support level for different EdgeOne plans is also not consistent.
Note:
For the description and plan restrictions of supported matching conditions, please refer to: Matching conditions.
Request domain name (Host)
Request client IP
Request client IP (prioritizing XFF header)
Request method (Method)
Request User-Agent header
Session cookie
XFF extended header
Request path (Path)
Custom request header
Request URL
Request source (Referer)
Network layer protocol
Application layer protocol
Request body
JA3 fingerprint
Supported Actions
Different custom protection rules support the following actions. For the description of different actions, please refer to Actions.
You can configure the return custom response content action for a single custom rule (only precise matching rules are supported). When a request matches the rule, EdgeOne will return the specified page and status code. You can also configure the custom response page to specify the page and status code used for all custom rules to block requests.