mirror of
https://github.com/shadow1ng/fscan.git
synced 2025-09-14 14:06:44 +08:00
修改webscan结构
This commit is contained in:
parent
fbf480b3a8
commit
600904b41a
@ -19,19 +19,16 @@ var SysInfo = GetSys()
|
||||
|
||||
type SystemInfo struct {
|
||||
OS string
|
||||
//ARCH string
|
||||
HostName string
|
||||
Groupid string
|
||||
Userid string
|
||||
Username string
|
||||
//UserHomeDir string
|
||||
}
|
||||
|
||||
func GetSys() SystemInfo {
|
||||
var sysinfo SystemInfo
|
||||
|
||||
sysinfo.OS = runtime.GOOS
|
||||
//sysinfo.ARCH = runtime.GOARCH
|
||||
name, err := os.Hostname()
|
||||
if err == nil {
|
||||
sysinfo.HostName = name
|
||||
@ -40,17 +37,14 @@ func GetSys() SystemInfo {
|
||||
}
|
||||
|
||||
u, err := user.Current()
|
||||
//fmt.Println(err,u)
|
||||
if err == nil {
|
||||
sysinfo.Groupid = u.Gid
|
||||
sysinfo.Userid = u.Uid
|
||||
sysinfo.Username = u.Username
|
||||
//sysinfo.UserHomeDir = u.HomeDir
|
||||
} else {
|
||||
sysinfo.Groupid = "1"
|
||||
sysinfo.Userid = "1"
|
||||
sysinfo.Username = name
|
||||
//sysinfo.UserHomeDir = u.HomeDir
|
||||
}
|
||||
|
||||
return sysinfo
|
||||
|
@ -217,10 +217,10 @@ func writecron(conn net.Conn, host string) (flag bool, text string, err error) {
|
||||
}
|
||||
if strings.Contains(text, "OK") {
|
||||
flag = true
|
||||
} //else {fmt.Println(text)}
|
||||
} //else {fmt.Println(text)}
|
||||
} //else {fmt.Println(text)}
|
||||
} //else {fmt.Println(text)}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
text = strings.TrimSpace(text)
|
||||
if len(text) > 50 {
|
||||
text = text[:50]
|
||||
|
@ -24,50 +24,34 @@ type Task struct {
|
||||
Poc *Poc
|
||||
}
|
||||
|
||||
|
||||
|
||||
func checkVul(tasks []Task, ticker *time.Ticker) <-chan Task {
|
||||
func CheckMultiPoc(req *http.Request, Pocs embed.FS, workers int, pocname string) {
|
||||
tasks := make(chan Task)
|
||||
var wg sync.WaitGroup
|
||||
results := make(chan Task)
|
||||
for _, task := range tasks {
|
||||
for i := 0; i < workers; i++ {
|
||||
go func() {
|
||||
wg.Add(1)
|
||||
go func(task Task) {
|
||||
defer wg.Done()
|
||||
<-ticker.C
|
||||
for task := range tasks {
|
||||
isVul, err := executePoc(task.Req, task.Poc)
|
||||
if err != nil {
|
||||
return
|
||||
continue
|
||||
}
|
||||
if isVul {
|
||||
results <- task
|
||||
result := fmt.Sprintf("%s %s", task.Req.URL, task.Poc.Name)
|
||||
common.LogSuccess(result)
|
||||
}
|
||||
}(task)
|
||||
}
|
||||
go func() {
|
||||
wg.Wait()
|
||||
close(results)
|
||||
wg.Done()
|
||||
}()
|
||||
return results
|
||||
}
|
||||
|
||||
|
||||
|
||||
func CheckMultiPoc(req *http.Request, Pocs embed.FS, rate int,pocname string) {
|
||||
rateLimit := time.Second / time.Duration(rate)
|
||||
ticker := time.NewTicker(rateLimit)
|
||||
defer ticker.Stop()
|
||||
var tasks []Task
|
||||
for _, poc := range LoadMultiPoc(Pocs,pocname) {
|
||||
}
|
||||
for _, poc := range LoadMultiPoc(Pocs, pocname) {
|
||||
task := Task{
|
||||
Req: req,
|
||||
Poc: poc,
|
||||
}
|
||||
tasks = append(tasks, task)
|
||||
}
|
||||
for result := range checkVul(tasks, ticker) {
|
||||
result := fmt.Sprintf("%s %s", result.Req.URL, result.Poc.Name)
|
||||
common.LogSuccess(result)
|
||||
tasks <- task
|
||||
}
|
||||
close(tasks)
|
||||
wg.Wait()
|
||||
}
|
||||
|
||||
func executePoc(oReq *http.Request, p *Poc) (bool, error) {
|
||||
|
@ -23,7 +23,7 @@ func Flag(Info *HostInfo) {
|
||||
flag.StringVar(&Info.Ports, "p", DefaultPorts, "Select a port,for example: 22 | 1-65535 | 22,80,3306")
|
||||
flag.StringVar(&Info.Command, "c", "", "exec command (ssh)")
|
||||
flag.IntVar(&Info.Threads, "t", 200, "Thread nums")
|
||||
flag.IntVar(&Info.IcmpThreads, "it", 3300, "Icmp Threads nums")
|
||||
flag.IntVar(&Info.IcmpThreads, "it", 1100, "Icmp Threads nums")
|
||||
flag.BoolVar(&Info.Isping, "np", false, "not to ping")
|
||||
flag.BoolVar(&Info.Ping, "ping", false, "using ping replace icmp")
|
||||
flag.BoolVar(&Info.IsSave, "no", false, "not to save output log")
|
||||
|
Loading…
Reference in New Issue
Block a user