3 回答
TA贡献1829条经验 获得超6个赞
如果我理解你的问题,你想读取文件,以某种方式检测到该文件被修改,并有一个方法将这些修改发送到客户端代码。
这不是文件的工作方式。
你有两个选择:
使用一些操作系统特定的 API 监听文件更改
使用无限循环读取文件。读取文件一次。将副本保存到内存中。在循环中一次又一次地读取同一个文件,直到新文件与副本不同并计算增量。
检查是否可以使用它push
来代替pull
获取新域。难不成控制文件域名的系统会直接给你推送数据?
如果loop
是唯一可能的选项,请在文件读取之间设置一些暂停时间以减少系统负载。
TA贡献1856条经验 获得超5个赞
如果您想“同时”执行此操作,您将返回一个通道,您将通过该通道发送您想要返回的多个内容:
https://play.golang.org/p/iYBGPwfYLYR
func DomainGrab() <-chan string {
ch := make(chan string, 1)
f, _ := os.Open("domains.txt")
defer f.Close()
scanner := bufio.NewScanner(f)
go func() {
// Loop over all lines in the file and print them.
for scanner.Scan() {
line := scanner.Text()
time.Sleep(2 * time.Second)
ch <- line
}
close(ch)
}()
return ch
}
TA贡献1906条经验 获得超10个赞
可能不是最好的解决方案。但是,我决定一起摆脱一个单独的功能,以覆盖更多领域。我会在下面发布我期望的代码。现在,我需要解析域,以便只扫描一次根 URL 和子域。
// Main
package main
import (
"log"
"fmt"
"time"
"net/http"
"github.com/gocolly/colly"
)
//var Domain string
var Target string
func main() {
c := colly.NewCollector()
c.OnError(func(r *colly.Response, err error) {
fmt.Println("Request URL:", r.Request.URL, "\n Failed with response:", r.StatusCode)
})
// Find and visit all links
c.OnHTML("a", func(e *colly.HTMLElement) {
e.Request.Visit(e.Attr("href"))
})
c.OnRequest(func(r *colly.Request) {
Domain := r.URL.String()
Target := BannerGrab(Domain)
fmt.Println(Domain)
fmt.Println(Target)
fmt.Println("Dropping By.. ", r.URL)
time.Sleep(1000 * time.Millisecond)
})
c.Visit("http://www.milliondollarhomepage.com/")
}
//CheckDB if not listed else add
//RiskDB
func BannerGrab(s string) string {
client := &http.Client{}
req, err := http.NewRequest("GET", s, nil)
if err != nil {
log.Fatalln(err)
}
req.Header.Set("User-Agent", "Authac/0.1")
resp, _ := client.Do(req)
serverEntry := resp.Header.Get("Server")
return serverEntry
}
- 3 回答
- 0 关注
- 114 浏览
添加回答
举报