以前用Python写过这个工具,前两天看了golang的基础,就想着用这个语言把这个工具重写一遍

先放张图

用法

    Example : Buster.exe -u=https://www.baidu.com -d=asp.txt -t=5
Buster是你的程序名字
-u后面填网址参数,格式如上
-d选字典
-t是线程数
当你第一次运行请直接在命令行运行你的程序,什么参数都别加,他会有提示信息告诉你怎么做的

话不多说,直接上代码,字典采用的以前搜集的一个珍藏的大字典,跑起来可能耗时比较久,文件外链会放在底下

package main

import (
"bufio"
"flag"
"fmt"
"io/ioutil"
"net/http"
"os"
"sync"
) var urls chan string
var no404URL = make(chan string)
var wg sync.WaitGroup //等待goroutine完成 func main() { var baseURL string
var dicPath string
var threadCount int
flag.StringVar(&baseURL, "u", "https://www.baidu.com", "website which you want to burst")
flag.StringVar(&dicPath, "d", "asp.txt", "dic which you want to use")
flag.IntVar(&threadCount, "t", 5, "number of Thread")
flag.Parse() if len(os.Args) == 1 {
fmt.Println("------------------------------------")
fmt.Println(" Author | Akkuamn")
fmt.Println("------------------------------------")
fmt.Println(" Update-v1.0 | 2017-02-07")
fmt.Println("-------------------------------------")
fmt.Printf("\nUsage : \n\tExample : %s -u=https://www.baidu.com -d=asp.txt -t=5\n\n", os.Args[0])
fmt.Printf("View more help via %s -h\n\n", os.Args[0])
listDic("dic")
} else {
dicPath = "./dic/" + dicPath
start(baseURL, dicPath, threadCount)
wg.Wait() //等待goroutine完成
}
} func start(baseURL string, dicPath string, threadCount int) { dicFile, dicError := os.OpenFile(dicPath, os.O_RDONLY, 0)
if dicError != nil {
fmt.Printf("\nOpenFile Error:文件打开出错,请检查字典文件是否存在,或文件名是否准确\n")
return
}
defer dicFile.Close() //把处理后的需要爆破的url全部传到信道urls
ReturnBurstURL(dicFile, baseURL) //单独开goroutine从信道no404URL取数据写入文件
go func() {
resultTxt, err := os.OpenFile("result.txt", os.O_CREATE|os.O_TRUNC|os.O_RDWR, 0660)
if err != nil {
fmt.Println("OpenFile Error:" + err.Error())
}
resultWriter := bufio.NewWriter(resultTxt)
defer resultTxt.Close()
for {
_, err = resultWriter.WriteString(<-no404URL)
if err != nil {
fmt.Println("resultWriter Error:" + err.Error())
}
resultWriter.Flush()
}
}() //并发访问网址并将状态码不为404的网址加入信道no404URL
for i := 0; i < threadCount; i++ {
wg.Add(1)
go func(i int) {
for len(urls) > 0 {
url := <-urls
status := HTTPStatus(url)
fmt.Printf("[%d]%s-----%s\n", i, status, url)
if status != "404 Not Found" {
no404URL <- status + "-----" + url + "\n"
}
}
wg.Done()
}(i)
}
} //返回HTTP访问状态码
func HTTPStatus(url string) (status string) {
client := http.DefaultClient
reqest, err := http.NewRequest("HEAD", url, nil)
if err == nil {
reqest.Header.Set("User-Agent", "Mozilla/5.0 (X11; Ubuntu; Linux i686; rv:51.0) Gecko/20100101 Firefox/51.0")
reqest.Header.Set("Accept", "text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8")
response, err1 := client.Do(reqest)
if err1 != nil {
fmt.Println("HTTPRequest Error:" + err1.Error())
} defer response.Body.Close()
return response.Status
} else {
fmt.Println("NewRequest Error:" + err.Error())
return "400 Bad Request"
}
} //把处理后的需要爆破的url全部传到信道urls
func ReturnBurstURL(fURL *os.File, baseurl string) {
var urlList []string
allURLTxt := bufio.NewScanner(fURL)
for allURLTxt.Scan() {
newurl := baseurl + "/" + allURLTxt.Text()
urlList = append(urlList, newurl)
}
urls = make(chan string, len(urlList))
for _, url := range urlList {
urls <- url
}
fmt.Printf("\n读取字典完成,准备开始,请等待...\n")
} //罗列出可用字典
func listDic(dicDir string) {
dirList, err := ioutil.ReadDir(dicDir)
if err != nil {
fmt.Println("ReadDir Error : " + err.Error() + "\n")
}
fmt.Println("Dic you can select : ")
for _, file := range dirList {
fmt.Printf(" %s\n", file.Name())
}
}

只编译了win平台下的,如果有需要可以自行编译

源码及字典及win程序

密码: g1gd

Golang初练手-多线程网站路径爆破的更多相关文章

  1. Windows API初练手 -- 疯狂写文件代码

    警告:恶作剧软件,慎用!仅供初学者研究代码所用!!! 提示:默认文件创建目录在"D:\test",如果需要使用的话请自行更改目录. 1. Windows API 版本 (调用系统函 ...

  2. Selenium_WebDriver登录模拟鼠标移动切换窗体等操作练习(cssSelector初练手)_Java

    cssSelector 据说cssSelector比xpath快. 所以,有固定ID属性的页面元素用By.id或者By.cssSelector("#id属性值")来找,有class ...

  3. Java学习路径及练手项目合集

    Java 在编程语言排行榜中一直位列前排,可知 Java 语言的受欢迎程度了. 实验楼上的[Java 学习路径]中将首先完成 Java基础.JDK.JDBC.正则表达式等基础实验,然后进阶到 J2SE ...

  4. Golang简易版 网站路径扫描demo

    package main import ( "bufio" "fmt" "net/http" "os" "re ...

  5. Python之路【第二十四篇】:Python学习路径及练手项目合集

      Python学习路径及练手项目合集 Wayne Shi· 2 个月前 参照:https://zhuanlan.zhihu.com/p/23561159 更多文章欢迎关注专栏:学习编程. 本系列Py ...

  6. Python学习路径及练手项目合集

    Python学习路径及练手项目合集 https://zhuanlan.zhihu.com/p/23561159

  7. 微信小程序初体验,入门练手项目--通讯录,部署上线(二)

    接上一篇<微信小程序初体验,入门练手项目--通讯录,后台是阿里云服务器>:https://www.cnblogs.com/chengxs/p/9898670.html 开发微信小程序最尴尬 ...

  8. 微信小程序初体验,入门练手项目--通讯录,后台是阿里云服务器(一)

    内容: 一.前言 二.相关概念 三.开始工作 四.启动项目起来 五.项目结构 六.设计理念 七.路由 八.部署线上后端服务 同步交流学习社区: https://www.mwcxs.top/page/4 ...

  9. thinkphp5项目--练手--企业单车网站(九)(友情链接)

    thinkphp5项目--练手--企业单车网站(九)(友情链接) 项目地址 fry404006308/BicycleEnterpriseWebsite: Bicycle Enterprise Webs ...

随机推荐

  1. DX9 空间坐标变换示例代码

    // @time 2012.3.25 // @author jadeshu #include <Windows.h> #include <d3d9.h> #include &l ...

  2. python 爬取qidian某一页全部小说

      本文纯粹用于技术练习,请勿用作非法途径 import re import urllib.request from bs4 import BeautifulSoup import time url= ...

  3. 阿里云Centos7 yum安装MySQL5.6

    安装mysql5姿势是要先安装带有可用的mysql5系列社区版资源的rpm包 [root@iZ28gvqe4biZ ~]# rpm -Uvh http://dev.mysql.com/get/mysq ...

  4. sitecore系统教程之禁用xDB和Xdb跟踪

    Sitecore体验管理包含未启用体验数据库(xDB)且无需购买xDB许可证情况下使用Sitecore内容管理系统. 除了在未启用xDB的情况下运行Sitecore Experience Platfo ...

  5. 【2017-03-28】JS基础、DOM操作

    一.JS基础 1.javascript功能 ⑴进行数据运算 ⑵控制浏览器功能 ⑶控制元素的属性.样式.内容 2.javascript位置和格式 可以放在html页的任意位置,也可以创建一个以js结尾的 ...

  6. HasThisTypePatternTriedToSneakInSomeGenericOrParameterizedTypePatternMatchingStuffAnywhereVisitor

    看到的最长的类名: HasThisTypePatternTriedToSneakInSomeGenericOrParameterizedTypePatternMatchingStuffAnywhere ...

  7. 20165305 苏振龙《Java程序设计》第八周学习总结

    第十二章 •如果想在main()以外独立设计流程,可以撰写类操作java.lang.Runnable接口,流程的进入点是操作在run()方法中. •如果想要加装主线程,就要创建 Thread 实例,要 ...

  8. flask实战-个人博客-使用蓝本模块化程序

    使用蓝本模块化程序 实例化flask提供的blueprint类就创建一个蓝本实例.像程序实例一样,我们可以为蓝本实例注册路由.错误处理函数.上下文处理函数,请求处理函数,甚至是单独的静态文件文件夹和模 ...

  9. centos 6.8操作系统安装arcgis server 10.4

    1.检查操作系统中软件包的安装,第一条和第二条是图形界面工具,可以不装. 可以用rpm -qa | grep 软件名   命令检查软件包是否已经安装 主机名不能包含下划线,可以用hostname检查主 ...

  10. 大数据学习路线:Hadoop集群同步技术分享

    今天给大家带来的技术分享是——Hadoop集群同步. 一.同步方式 选择一个机器,作为时间服务器(这里选择hadoop01),所有的机器与这台集群时间进行定时的同步,比如,每隔十分钟,同步一次时间. ...