代码拉取完成,页面将自动刷新
package ipv4info
import (
"context"
"io/ioutil"
"regexp"
"strconv"
"github.com/projectdiscovery/subfinder/pkg/subscraping"
)
// Source is the passive scraping agent
type Source struct{}
// Run function returns all subdomains found with the service
func (s *Source) Run(ctx context.Context, domain string, session *subscraping.Session) <-chan subscraping.Result {
results := make(chan subscraping.Result)
go func() {
resp, err := session.NormalGetWithContext(ctx, "http://ipv4info.com/search/"+domain)
if err != nil {
results <- subscraping.Result{Source: s.Name(), Type: subscraping.Error, Error: err}
close(results)
return
}
body, err := ioutil.ReadAll(resp.Body)
if err != nil {
results <- subscraping.Result{Source: s.Name(), Type: subscraping.Error, Error: err}
resp.Body.Close()
close(results)
return
}
resp.Body.Close()
src := string(body)
regxTokens := regexp.MustCompile("/ip-address/(.*)/" + domain)
matchTokens := regxTokens.FindAllString(src, -1)
if len(matchTokens) <= 0 {
close(results)
return
}
token := matchTokens[0]
resp, err = session.NormalGetWithContext(ctx, "http://ipv4info.com"+token)
if err != nil {
results <- subscraping.Result{Source: s.Name(), Type: subscraping.Error, Error: err}
close(results)
return
}
body, err = ioutil.ReadAll(resp.Body)
if err != nil {
results <- subscraping.Result{Source: s.Name(), Type: subscraping.Error, Error: err}
resp.Body.Close()
close(results)
return
}
resp.Body.Close()
src = string(body)
regxTokens = regexp.MustCompile("/dns/(.*?)/" + domain)
matchTokens = regxTokens.FindAllString(src, -1)
if len(matchTokens) <= 0 {
close(results)
return
}
token = matchTokens[0]
resp, err = session.NormalGetWithContext(ctx, "http://ipv4info.com"+token)
if err != nil {
results <- subscraping.Result{Source: s.Name(), Type: subscraping.Error, Error: err}
close(results)
return
}
body, err = ioutil.ReadAll(resp.Body)
if err != nil {
results <- subscraping.Result{Source: s.Name(), Type: subscraping.Error, Error: err}
resp.Body.Close()
close(results)
return
}
resp.Body.Close()
src = string(body)
regxTokens = regexp.MustCompile("/subdomains/(.*?)/" + domain)
matchTokens = regxTokens.FindAllString(src, -1)
if len(matchTokens) <= 0 {
close(results)
return
}
token = matchTokens[0]
resp, err = session.NormalGetWithContext(ctx, "http://ipv4info.com"+token)
if err != nil {
results <- subscraping.Result{Source: s.Name(), Type: subscraping.Error, Error: err}
close(results)
return
}
body, err = ioutil.ReadAll(resp.Body)
if err != nil {
results <- subscraping.Result{Source: s.Name(), Type: subscraping.Error, Error: err}
resp.Body.Close()
close(results)
return
}
resp.Body.Close()
src = string(body)
for _, match := range session.Extractor.FindAllString(src, -1) {
results <- subscraping.Result{Source: s.Name(), Type: subscraping.Subdomain, Value: match}
}
nextPage := 1
for {
further := s.getSubdomains(ctx, domain, &nextPage, src, session, results)
if !further {
break
}
}
close(results)
}()
return results
}
// Name returns the name of the source
func (s *Source) Name() string {
return "ipv4info"
}
func (s *Source) getSubdomains(ctx context.Context, domain string, nextPage *int, src string, session *subscraping.Session, results chan subscraping.Result) bool {
for {
select {
case <-ctx.Done():
return false
default:
regxTokens := regexp.MustCompile("/subdomains/.*/page" + strconv.Itoa(*nextPage) + "/" + domain + ".html")
matchTokens := regxTokens.FindAllString(src, -1)
if len(matchTokens) == 0 {
return false
}
token := matchTokens[0]
resp, err := session.NormalGetWithContext(ctx, "http://ipv4info.com"+token)
if err != nil {
results <- subscraping.Result{Source: s.Name(), Type: subscraping.Error, Error: err}
return false
}
body, err := ioutil.ReadAll(resp.Body)
if err != nil {
results <- subscraping.Result{Source: s.Name(), Type: subscraping.Error, Error: err}
resp.Body.Close()
return false
}
resp.Body.Close()
src = string(body)
for _, match := range session.Extractor.FindAllString(src, -1) {
results <- subscraping.Result{Source: s.Name(), Type: subscraping.Subdomain, Value: match}
}
*nextPage++
return true
}
}
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。