当前位置: 首页 > article >正文

Subfinder扩展开发终极指南:从零构建高级子域名发现模块

Subfinder扩展开发终极指南从零构建高级子域名发现模块【免费下载链接】subfinder项目地址: https://gitcode.com/gh_mirrors/subf/subfinderSubfinder是一款功能强大的子域名发现工具能够帮助安全研究人员和开发者快速枚举目标域名下的子域名。本指南将带你了解如何为Subfinder开发自定义扩展模块轻松扩展其被动子域名发现能力。为什么开发Subfinder扩展模块Subfinder通过集成多种数据源实现高效的子域名发现其核心优势在于可扩展性。官方已提供alienvault、censys等30种数据源但互联网上还有大量未被集成的优质API和数据源。开发自定义模块可以接入企业内部漏洞情报平台整合行业特定数据源实现自定义过滤和处理逻辑优化特定场景下的子域名发现效率Subfinder扩展开发核心概念理解Source接口Subfinder的扩展系统基于Go语言的接口设计所有数据源都实现了Source接口。查看v2/pkg/subscraping/types.go文件核心定义如下// Source is an interface inherited by each passive source type Source interface { Run(context.Context, string, *Session) -chan Result Name() string IsDefault() bool HasRecursiveSupport() bool NeedsKey() bool AddApiKeys([]string) Statistics() Statistics }每个接口方法都有特定职责Run(): 核心执行方法返回子域名结果通道Name(): 返回数据源名称小写IsDefault(): 是否作为默认数据源启用NeedsKey(): 是否需要API密钥认识Session和Result结构Session对象封装了HTTP客户端、子域名提取器和速率限制器定义在v2/pkg/subscraping/agent.go中提供了Get()、Post()等HTTP请求方法。Result结构包含子域名发现结果type Result struct { Type ResultType // Subdomain或Error Source string // 数据源名称 Value string // 子域名值 Error error // 错误信息 }开发步骤构建自定义数据源模块1. 创建模块文件在v2/pkg/subscraping/sources/目录下创建新的数据源目录和文件例如v2/pkg/subscraping/sources/mycustomsource/mycustomsource.go2. 实现Source接口以下是一个基础模板实现了所有必要的接口方法package mycustomsource import ( context fmt github.com/projectdiscovery/subfinder/v2/pkg/subscraping ) type Source struct { apiKeys []string stats subscraping.Statistics } func (s *Source) Run(ctx context.Context, domain string, session *subscraping.Session) -chan subscraping.Result { results : make(chan subscraping.Result) go func() { defer close(results) // 实现你的子域名发现逻辑 // 1. 构建API请求 // 2. 发送请求并处理响应 // 3. 提取子域名 // 4. 发送结果到通道 results - subscraping.Result{ Type: subscraping.Subdomain, Source: s.Name(), Value: example.subdomain.com, } }() return results } func (s *Source) Name() string { return mycustomsource } func (s *Source) IsDefault() bool { return false // 不作为默认数据源 } func (s *Source) HasRecursiveSupport() bool { return false // 不支持递归查询 } func (s *Source) NeedsKey() bool { return true // 需要API密钥 } func (s *Source) AddApiKeys(keys []string) { s.apiKeys keys } func (s *Source) Statistics() subscraping.Statistics { return s.stats }3. 集成HTTP请求处理利用Session对象提供的HTTP方法发送请求// 发送GET请求示例 resp, err : session.Get(ctx, https://api.example.com/subdomains?domaindomain, , nil) if err ! nil { results - subscraping.Result{Type: subscraping.Error, Source: s.Name(), Error: err} return } defer session.DiscardHTTPResponse(resp) // 读取响应内容 body, err : io.ReadAll(resp.Body) if err ! nil { results - subscraping.Result{Type: subscraping.Error, Source: s.Name(), Error: err} return } // 使用内置提取器提取子域名 subdomains : session.Extractor.Extract(string(body)) for _, subdomain : range subdomains { results - subscraping.Result{ Type: subscraping.Subdomain, Source: s.Name(), Value: subdomain, } }4. 注册数据源编辑subscraping/sources.go文件添加你的数据源import ( // ...其他导入 github.com/projectdiscovery/subfinder/v2/pkg/subscraping/sources/mycustomsource ) func GetAllSources() []subscraping.Source { return []subscraping.Source{ // ...其他数据源 mycustomsource.Source{}, } }测试与调试本地测试方法使用Go的测试框架编写单元测试// 在mycustomsource_test.go中 package mycustomsource import ( context testing github.com/projectdiscovery/subfinder/v2/pkg/subscraping ) func TestSource(t *testing.T) { source : Source{} session, err : subscraping.NewSession(example.com, , nil, 10) if err ! nil { t.Fatal(err) } results : source.Run(context.Background(), example.com, session) for result : range results { if result.Error ! nil { t.Error(result.Error) } else { t.Log(result.Value) } } }集成测试编译并运行Subfinder验证新模块git clone https://gitcode.com/gh_mirrors/subf/subfinder cd subfinder/v2 go build -o subfinder cmd/subfinder/main.go ./subfinder -d example.com -s mycustomsource -vSubfinder运行时会显示各数据源发现的子域名包括你开发的自定义模块高级技巧与最佳实践处理API速率限制使用MultiRateLimiter控制请求频率// 在Run方法中 mrlErr : session.MultiRateLimiter.Take(s.Name()) if mrlErr ! nil { results - subscraping.Result{Type: subscraping.Error, Source: s.Name(), Error: mrlErr} return }实现API密钥轮换当NeedsKey()返回true时Subfinder会自动传入API密钥func (s *Source) Run(...) { // 循环使用所有提供的API密钥 for _, key : range s.apiKeys { // 使用key发送请求 } }错误处理与重试机制实现指数退避重试逻辑backoff : 1 * time.Second for i : 0; i 3; i { resp, err : session.Get(...) if err nil { // 处理响应 break } time.Sleep(backoff) backoff * 2 }发布与贡献开发完成后你可以将模块提交到Subfinder官方仓库成为社区贡献者在examples/main.go中添加使用示例更新README.md文档说明新模块的功能和使用方法通过遵循这些步骤你可以轻松扩展Subfinder的功能将其打造成更强大的子域名发现工具。无论是个人使用还是团队协作自定义模块都能显著提升子域名发现的效率和范围。【免费下载链接】subfinder项目地址: https://gitcode.com/gh_mirrors/subf/subfinder创作声明:本文部分内容由AI辅助生成(AIGC),仅供参考

相关文章:

Subfinder扩展开发终极指南:从零构建高级子域名发现模块

Subfinder扩展开发终极指南:从零构建高级子域名发现模块 【免费下载链接】subfinder 项目地址: https://gitcode.com/gh_mirrors/subf/subfinder Subfinder是一款功能强大的子域名发现工具,能够帮助安全研究人员和开发者快速枚举目标域名下的子域…...

终极Evergreen UI包大小优化指南:如何减少65%的React组件库体积

终极Evergreen UI包大小优化指南:如何减少65%的React组件库体积 【免费下载链接】evergreen 🌲 Evergreen React UI Framework by Segment 项目地址: https://gitcode.com/gh_mirrors/evergreen1/evergreen 在现代前端开发中,React组件…...

终极指南:如何使用Jazzy为CocoaLumberjack生成专业API文档

终极指南:如何使用Jazzy为CocoaLumberjack生成专业API文档 【免费下载链接】CocoaLumberjack 项目地址: https://gitcode.com/gh_mirrors/coc/CocoaLumberjack CocoaLumberjack是iOS和macOS开发中广泛使用的日志框架,提供高效、灵活的日志记录功…...

Win10 将未分配的磁盘空间合并到C盘该怎么做?一文教你3种方法

平时用电脑,下载文件、存视频,或是安装各类软件,要是没特意去设置安装路径和下载路径,这些东西都会默认存到C盘里。用的时间久了,C盘空间就会一点点被占满,电脑运行也会跟着越来越慢、偶尔卡顿。想改善这种…...

终极指南:如何用deej打造你的专属硬件音量控制器

终极指南:如何用deej打造你的专属硬件音量控制器 【免费下载链接】deej Set app volumes with real sliders! deej is an Arduino & Go project to let you build your own hardware mixer for Windows and Linux 项目地址: https://gitcode.com/gh_mirrors/d…...

isaac_ros_visual_slam性能优化指南:提升实时定位精度的5个技巧

isaac_ros_visual_slam性能优化指南:提升实时定位精度的5个技巧 【免费下载链接】isaac_ros_visual_slam Visual odometry package based on hardware-accelerated NVIDIA Elbrus library with world class quality and performance. 项目地址: https://gitcode.c…...

探索A星算法在Matlab路径规划中的奇妙之旅

A星算法 A*算法 自己研究编写的Matlab路径规划算法 Astar算法走迷宫 可自行设置起始点,目标点,自由更换地图。 ——————————————————— 可以和人工势场法融合 动态障碍物在路径规划的领域里,A星(A*)算…...

论文阅读:arxiv 2025 A Comprehensive Survey on Trustworthiness in Reasoning with Large Language Models

总目录 大模型相关研究:https://blog.csdn.net/WhiffeYF/article/details/142132328 https://arxiv.org/pdf/2509.03871 https://www.doubao.com/chat/24861847477344002 论文翻译:https://whiffe.github.io/Paper_Tra...

Distributions.jl高级特性:截断分布、混合模型与矩阵变量分布

Distributions.jl高级特性:截断分布、混合模型与矩阵变量分布 【免费下载链接】Distributions.jl A Julia package for probability distributions and associated functions. 项目地址: https://gitcode.com/gh_mirrors/di/Distributions.jl Distributions.…...

OpenObserve存储性能终极对比:云厂商对象存储vs自建MinIO的完整指南

OpenObserve存储性能终极对比:云厂商对象存储vs自建MinIO的完整指南 【免费下载链接】openobserve 🚀 10x easier, 🚀 140x lower storage cost, 🚀 high performance, 🚀 petabyte scale - Elasticsearch/Splunk/Data…...

OpenObserve缓存策略调优:基于查询模式的智能缓存配置终极指南

OpenObserve缓存策略调优:基于查询模式的智能缓存配置终极指南 【免费下载链接】openobserve 🚀 10x easier, 🚀 140x lower storage cost, 🚀 high performance, 🚀 petabyte scale - Elasticsearch/Splunk/Datadog a…...

突破日志大数据瓶颈:OpenObserve批量导入工具的分片与断点续传技术全解析

突破日志大数据瓶颈:OpenObserve批量导入工具的分片与断点续传技术全解析 【免费下载链接】openobserve 🚀 10x easier, 🚀 140x lower storage cost, 🚀 high performance, 🚀 petabyte scale - Elasticsearch/Splunk…...

如何使用Mapper库快速实现Swift对象的JSON解析?新手入门指南

如何使用Mapper库快速实现Swift对象的JSON解析?新手入门指南 【免费下载链接】mapper A JSON deserialization library for Swift 项目地址: https://gitcode.com/gh_mirrors/map/mapper Mapper是一款专为Swift打造的JSON反序列化库,能够帮助开发…...

Erlang/OTP性能优化终极指南:10个内存管理与垃圾回收调优技巧

Erlang/OTP性能优化终极指南:10个内存管理与垃圾回收调优技巧 【免费下载链接】otp Erlang/OTP 项目地址: https://gitcode.com/gh_mirrors/ot/otp Erlang/OTP作为构建高并发、分布式系统的强大平台,其性能优化尤其是内存管理和垃圾回收调优&…...

腾讯版小龙虾正式上线!支持Win和Mac系统WorkBuddy Claw安装与全平台接入指南

在日常办公中,你是否经常被繁琐的重复工作占据大量时间?远程协作时,无法及时调度电脑完成任务?腾讯推出的 WorkBuddy Claw 正是为解决这些痛点而来 —— 这是一款免部署、安装即用的 AI 办公助手,能自主完成办公任务&a…...

终极指南:使用 SVG.js 创建完美响应式 SVG 图形的最佳方法

终极指南:使用 SVG.js 创建完美响应式 SVG 图形的最佳方法 【免费下载链接】svg.js The lightweight library for manipulating and animating SVG 项目地址: https://gitcode.com/gh_mirrors/sv/svg.js SVG.js 是一款轻量级的 SVG 操作与动画库,…...

如何用Mitt打造高效的Node.js后端事件驱动架构

如何用Mitt打造高效的Node.js后端事件驱动架构 【免费下载链接】mitt 🥊 Tiny 200 byte functional event emitter / pubsub. 项目地址: https://gitcode.com/gh_mirrors/mi/mitt Mitt是一个轻量级的事件发射器(Event Emitter)库&…...

Sarama高级配置终极指南:10个性能调优参数和监控指标解析

Sarama高级配置终极指南:10个性能调优参数和监控指标解析 【免费下载链接】sarama Sarama is a Go library for Apache Kafka. 项目地址: https://gitcode.com/gh_mirrors/sar/sarama Sarama是一个用于Apache Kafka的Go语言库,提供了高效的消息生…...

【书生·浦语】internlm2-chat-1.8b效果展示:中文游戏剧情生成+角色设定构建

【书生浦语】internlm2-chat-1.8b效果展示:中文游戏剧情生成角色设定构建 1. 开篇:当AI成为你的游戏编剧 想象一下,你正在构思一款全新的游戏。脑海里已经有了一个模糊的世界观,几个性格迥异的角色,但当你坐下来&…...

5分钟掌握Bonjour零配置网络发现技术:让设备自动找到彼此的终极指南

5分钟掌握Bonjour零配置网络发现技术:让设备自动找到彼此的终极指南 【免费下载链接】bonjour A Bonjour/Zeroconf protocol implementation in JavaScript 项目地址: https://gitcode.com/gh_mirrors/bo/bonjour 在当今智能家居与物联网飞速发展的时代&…...

Super Qwen Voice World部署教程:Docker Compose多服务编排方案

Super Qwen Voice World部署教程:Docker Compose多服务编排方案 想不想亲手搭建一个复古像素风的AI语音设计中心?在这里,你只需要用文字描述,比如“一个非常焦急、快要哭出来的语气”,AI就能为你生成对应的声音&#…...

Qwen3-ASR-1.7B保姆级教程:Windows WSL2 + NVIDIA驱动环境下完整部署流程

Qwen3-ASR-1.7B保姆级教程:Windows WSL2 NVIDIA驱动环境下完整部署流程 1. 学习目标与前置准备 本教程将手把手教你如何在Windows系统上,通过WSL2和NVIDIA驱动环境,完整部署Qwen3-ASR-1.7B语音识别工具。学完本教程,你将能够&a…...

5步掌握深度聚类:无需标签也能学会图像特征提取

5步掌握深度聚类:无需标签也能学会图像特征提取 【免费下载链接】deepcluster Deep Clustering for Unsupervised Learning of Visual Features 项目地址: https://gitcode.com/gh_mirrors/de/deepcluster 深度聚类(DeepCluster)是一种…...

[特殊字符] GLM-4V-9B训练细节:预训练与微调阶段数据构成揭秘

GLM-4V-9B训练细节:预训练与微调阶段数据构成揭秘 1. 项目概述 GLM-4V-9B是一个强大的多模态大模型,能够同时处理图像和文本信息,实现真正的多模态对话。这个模型在训练过程中采用了精心设计的数据策略,使其在理解和生成能力上都…...

RVC开源项目深度解析:检索式语音转换原理与WebUI架构

RVC开源项目深度解析:检索式语音转换原理与WebUI架构 1. 引言:从AI翻唱到语音克隆,RVC带来了什么? 你可能在社交媒体上听过用AI“翻唱”的歌曲,或者见过一键变声的有趣视频。这些效果的背后,往往有一个共…...

不止于供货商:福尔蒂技术团队驻厂1962工时,解决PLC以外的实际问题

最近有位做化纤设备集成的朋友跟我聊起一个细节:他们产线上的某台进口PLC频繁报错,排查两周没找到根因,最后发现不是控制器本身的问题,而是母粒在高温挤出过程中析出微量挥发物,沉积在传感器接口处导致信号干扰。这种问…...

ollama部署embeddinggemma-300m:开源可部署+多语言+端侧友好三重优势

ollama部署embeddinggemma-300m:开源可部署多语言端侧友好三重优势 本文介绍如何使用Ollama快速部署EmbeddingGemma-300m嵌入模型,这是一个仅有3亿参数的开源多语言嵌入模型,专为端侧设备优化,支持100多种语言,适合搜索…...

Jimeng AI Studio参数详解:CFG强度对构图稳定性影响深度分析

Jimeng AI Studio参数详解:CFG强度对构图稳定性影响深度分析 1. 引言:为什么CFG强度如此重要? 当你使用Jimeng AI Studio生成图片时,可能会发现同样的提示词,调整CFG强度后生成的图片效果天差地别。有时候图片精美绝…...

图片旋转判断效果展示:倾斜15°/30°/75°图像识别准确率达99.2%

图片旋转判断效果展示:倾斜15/30/75图像识别准确率达99.2% 你有没有遇到过这种情况?从手机或扫描仪里导出的图片,莫名其妙就歪了。可能是15度,也可能是30度,甚至更夸张。一张张手动去旋转、去对齐,眼睛都看…...

YOLO12高性能部署:异步FastAPI服务QPS达120+并发请求不丢帧

YOLO12高性能部署:异步FastAPI服务QPS达120并发请求不丢帧 1. 项目概述 YOLO12是Ultralytics在2025年推出的实时目标检测模型最新版本,作为YOLOv11的升级版,通过引入注意力机制优化了特征提取网络,在保持实时推理速度的同时显著…...