如何使用PoW-Shield防御DDoS和垃圾邮件攻击

关于PoW-Shield

PoW-Shield是一款功能强大的网络安全防御工具,该工具可以帮助广大研究人员和用户抵御DDoS攻击和垃圾邮件攻击。除此之外,PoW-Shield还带有Web应用防火墙功能,并提供了Docker镜像以方便实现快速轻量级部署。

PoW-Shield可以通过充当代理的形式,并利用后端服务和最终用户之间的工作证明,在OSI应用层提供DDoS保护。该项目旨在提供针对通用验证码方法的替代方案,比如说Google的ReCaptcha,而这一点对于社区来说一直都是一个难题。访问受PoW-Shield保护的Web服务也非常简单,直接打开浏览器并填写目标站点URL,浏览器将会自动为我们完成剩余的安全验证。

PoW-Shield旨在通过一个单一Web应用或Docker镜像提供下列服务:

  • 工作证明验证
  • 访问频率限制和IP黑名单
  • Web应用程序防火墙

功能介绍

  • Web服务结构
  • 代理功能
  • PoW实现
  • Docker化部署
  • IP黑名单功能
  • 访问频率限制
  • 单元测试
  • Web应用程序防火墙实现
  • 多实例同步(Redis)

工具下载&使用

Node.js

首先,我们可以使用下列命令将该项目源码克隆至本地:

  1. git clone https://github.com/RuiSiang/PoW-Shield.git 

接下来,安装该工具所需的依赖组件:

  1. npm install 

然后配置工具相关信息:

  1. cp -n .env.example .env 
  2.  
  3. # edit .env 
  4.  
  5. nano .env 

运行下列命令执行代码构建:

  1. npm run build 

执行并同时启动数据库(建议使用轻量级的Redis):

  1. # install redis first 
  2.  
  3. # sudo apt-get install redis-server 
  4.  
  5. npm start 

执行但不启动数据库:

  1. npm run start:standalone # linux 
  2.  
  3. npm run start:standalone-win # windows 

测试工具功能(可选):

  1. npm test 

Docker(库)

Docker带Redis数据库运行:

  1. docker run -p 3000:3000 -e BACKEND_URL="http://example.com" -d ruisiang/pow-shield 

Docker不带数据库运行:

  1. docker run -p 3000:3000 -e BACKEND_URL="http://example.com" -e NODE_ENV="standalone" -d ruisiang/pow-shield 

Docker-Compose

首先我们需要使用下列命令配置docker-compose.example.yaml:

  1. cp -n docker-compose.example.yaml docker-compose.yaml 
  2.  
  3. # edit docker-compose.yaml 
  4.  
  5. nano docker-compose.yaml 

接下来,我们就可以启动容器了:

  1. docker-compose up 

工具配置

配置方法:

  1. nodejs:(样例:.env.example) 
  2.  
  3. docker-compose:docker-compose.yaml(样例:docker-compose.example.yaml) 
  4.  
  5. docker run:-e参数 

环境变量

常用配置:

  • PORT:待监听端口,默认为3000
  • SESSION_KEY:cookie签名所需的密钥
  • BACKEND_URL:代理验证流量的目的地址,接受IP和URL

数据库选项(Redis):

  • DATABASE_HOST:Redis服务主机地址,默认为127.0.0.1
  • DATABASE_PORT:Redis服务端口,默认为6379
  • DATABASE_PASSWORD:Redis服务密码,默认为空

PoW选项:

  • POW:是否开启PoW功能,默认为on(开)
  • NONCE_VALIDITY:指定Nonce生成后多久才发送至服务器,默认为60000
  • INITIAL_DIFFICULTY:初始难度,生成的哈希中前导0位的数量,默认为13

访问频率选项:

  • RATE_LIMIT:是否开启频率限制,默认为on(开)
  • RATE_LIMIT_SAMPLE_MINUTES:指定会话/ip的统计信息重置间隔分钟数,默认为60
  • RATE_LIMIT_SESSION_THRESHOLD:单个会话在触发令牌撤销之前能发送的请求数量,默认为100
  • RATE_LIMIT_BAN_IP:是否开启IP黑名单功能,默认为on(开)
  • RATE_LIMIT_IP_THRESHOLD:指定会话/ip在地址被拉黑之前发送的请求数量,莫尔奈威500
  • RATE_LIMIT_BAN_MINUTES:IP地址拉黑时间,默认为15分钟

WAF选项:

  • WAF
  • WAF_URL_EXCLUDE_RULES:是否开启Web应用防火墙,默认为on(开)
  • WAF_HEADER_EXCLUDE_RULES:在扫描请求URL时引入额外规则
  • WAF_BODY_EXCLUDE_RULES:在扫描请求Body时引入额外规则

许可证协议

本项目的开发与发布遵循BSD 3-Clause开源许可证协议。

功能演示视频

视频地址:https://you*tu.be/zeNKUDR7_Jc

项目地址

PoW-Shield:【GitHub传送门

 

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/130448.html<

(0)
运维的头像运维
上一篇2025-02-26 02:19
下一篇 2025-02-26 02:20

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注