fscan/plugins/web/webpoc.go
ZacharyZcR 95497da8ca refactor: 优化插件系统设计,消除代码重复
主要改进:
1. 修复Services插件端口数据重复问题
   - 删除插件结构体中的ports字段和GetPorts()方法
   - 系统统一使用注册时的端口信息

2. 引入BasePlugin基础结构体
   - 消除51个插件中重复的name字段和Name()方法
   - 统一插件基础功能,简化代码维护

3. 统一插件接口设计
   - 保持向后兼容,功能完全不变
   - 代码更简洁,符合工程最佳实践

影响范围:
- services插件:29个文件简化
- web插件:2个文件简化
- local插件:21个文件简化
- 总计删除约150行重复代码
2025-09-02 05:36:12 +08:00

52 lines
1018 B
Go

package web
import (
"context"
"fmt"
"github.com/shadow1ng/fscan/common"
"github.com/shadow1ng/fscan/plugins"
"github.com/shadow1ng/fscan/webscan"
)
// WebPocPlugin Web漏洞扫描插件
type WebPocPlugin struct {
plugins.BasePlugin
}
// NewWebPocPlugin 创建Web POC插件
func NewWebPocPlugin() *WebPocPlugin {
return &WebPocPlugin{
BasePlugin: plugins.NewBasePlugin("webpoc"),
}
}
// Scan 执行Web POC扫描
func (p *WebPocPlugin) Scan(ctx context.Context, info *common.HostInfo) *WebScanResult {
if common.DisablePocScan {
return &WebScanResult{
Success: false,
Error: fmt.Errorf("POC扫描已禁用"),
}
}
target := fmt.Sprintf("%s:%s", info.Host, info.Ports)
common.LogSuccess(fmt.Sprintf("WebPOC %s 开始扫描", target))
// 直接执行Web扫描
WebScan.WebScan(info)
return &WebScanResult{
Success: true,
VulInfo: "WebPOC扫描完成",
}
}
// init 自动注册插件
func init() {
RegisterWebPlugin("webpoc", func() WebPlugin {
return NewWebPocPlugin()
})
}