为了账号安全,请及时绑定邮箱和手机立即绑定

在 golang 中迭代多个返回值

在 golang 中迭代多个返回值

Go
跃然一笑 2023-05-08 16:10:54
我正在尝试从包含域(未知数量)的文本文件中获取输入,然后将每个域用作参数并获取其服务器类型。正如预期的那样,这只会返回最后一个域。如何迭代多个返回值?下面是代码。// 测试包主import (    "bufio"    "time"    "os"    "fmt"    "net/http"    //"github.com/gocolly/colly")var Domain stringvar Target stringfunc main() {    Domain := DomainGrab()    Target := BannerGrab(Domain)    //CheckDB if not listed then add else skip    //RiskDB    //Email    fmt.Println(Domain)    fmt.Println(Target)}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}func DomainGrab() string {    //c := colly.NewCollector()// Open the file.    f, _ := os.Open("domains.txt")    defer f.Close()    // Create a new Scanner for the file.    scanner := bufio.NewScanner(f)    // Loop over all lines in the file and print them.    for scanner.Scan() {        line := scanner.Text()        time.Sleep(2 * time.Second)        //fmt.Println(line)        return line    }    return Domain}
查看完整描述

3 回答

?
肥皂起泡泡

TA贡献1829条经验 获得超6个赞

如果我理解你的问题,你想读取文件,以某种方式检测到该文件被修改,并有一个方法将这些修改发送到客户端代码。

这不是文件的工作方式。

你有两个选择:

  1. 使用一些操作系统特定的 API 监听文件更改 

  2. 使用无限循环读取文件。读取文件一次。将副本保存到内存中。在循环中一次又一次地读取同一个文件,直到新文件与副本不同并计算增量。

检查是否可以使用它push来代替pull获取新域。难不成控制文件域名的系统会直接给你推送数据?

如果loop是唯一可能的选项,请在文件读取之间设置一些暂停时间以减少系统负载。

查看完整回答
反对 回复 2023-05-08
?
RISEBY

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

}


查看完整回答
反对 回复 2023-05-08
?
隔江千里

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

    //Email



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


}



查看完整回答
反对 回复 2023-05-08
  • 3 回答
  • 0 关注
  • 114 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信