通过API,可以完全控制云WAF的所有功能 除了/api/config/下的接口
一定需要填写IP白名单 (不添加IP白名单则会被拒绝访问、如果没固定IP 则填写*号代表允许所有IP)
__WAF_KEY = 接口密钥 (在WAF设置页面 - API 接口中获取)
waf_request_time = 当前请求时间的 uinx 时间戳 ( php: time() / python: time.time() )
waf_request_token = md5(string(request_time) + md5(api_sk))
注意事项:
1、请统一使用 POST 方式请求 API 接口
2、请求的参数为 Json 数据格式
3、为了安全考虑,请务必添加 IP 白名单 (不添加IP白名单则会被拒绝访问、如果没固定IP 则填写*号代表允许所有IP)
4、所有响应内容统一为 Json 数据格式
如果服务器时间和当前时间相差超过 2分钟,则会被拒绝访问。
请确保服务器时间和当前时间一致。
# coding: utf-8
import time
import hashlib
import json
import requests
class WafApi:
__WAF_KEY = 'op51JCeKAdqa7AUtKae7ONrMeW8FdAWA'
__WAF_PANEL = 'https://192.168.10.10:8379'
def __get_md5(self, s: str) -> str:
"""计算字符串的 MD5 值"""
return hashlib.md5(s.encode('utf-8')).hexdigest()
def __get_headers(self) -> dict:
"""生成请求头中的 waf_request_time 和 waf_request_token"""
time_now = str(int(time.time()))
token = self.__get_md5(time_now + self.__get_md5(self.__WAF_KEY))
return {
'waf_request_time': time_now,
'waf_request_token': token,
"Content-Type":"application/json"
}
def get_logs(self):
"""获取站点日志列表"""
url = f"{self.__WAF_PANEL}/api/wafmastersite/get_site_list"
headers = self.__get_headers()
payload = {'p': 1, 'p_size': 20, 'site_name': ""}
try:
response = requests.post(
url,
headers=headers,
data=json.dumps(payload),
timeout=10,
verify=False
)
if response.status_code == 200:
json_data = response.json()
if json_data.get('code') == 0:
return json_data
else:
print("接口返回失败:", json_data.get('msg', '未知错误'))
else:
print(f"请求失败,状态码:{response.status_code}")
print("请检查当前IP是否 在API访问白名单内")
except requests.RequestException as e:
print(f"网络请求异常: {e}")
return None
if __name__ == '__main__':
waf_api = WafApi()
logs = waf_api.get_logs()
print(logs)URL: /api/wafmastersite/get_site_list
METHOD: POST
Request:
{p: 1, p_size: 20, site_name: ""}URL: /api/report/attack_report_log
METHOD: POST
Request:
{p: 1, p_size: 20, keyword: "", query_data: "", filters: []}URL: /api/limit/get_ip
METHOD: POST
Request:
{p: 1, types: 1, p_size: 10, keyword: ""} URL: /api/limit/get_ip
METHOD: POST
Request:
{p: 1, types: 0, p_size: 10, keyword: ""} URL: /api/limit/get_url
METHOD: POST
Request:
{types: 1, p: 1, p_size: 10, keyword: ""}URL: /api/limit/get_url
METHOD: POST
Request:
{types: 0, p: 1, p_size: 10, keyword: ""}URL: /api/limit/get_ua
METHOD: POST
Request:
{p: 1, types: 1, p_size: 10, keyword: ""}URL: /api/limit/get_ua
METHOD: POST
Request:
{p: 1, types: 0, p_size: 10, keyword: ""}- 打开WAF 后台F12 查看接口地址
- 复制接口地址到浏览器中访问
- 查看请求的参数
- 复制请求的参数到API 中
- 发送请求
- 查看响应内容