IDA插件--FRC(Fast Rename from Clipboard)开发
FRC(Fast Rename from Clipboard)前言 在分析某款固件过程中,由于去了符号表,但是好多的函数名还是能够根据其调用链分析出来的,例如: 我们不难猜测出这个一个注册函数的功能,只需要逐个复制字符串然后再到后面的sub_xxxx上重命名黏贴就能手动恢复函数名了。这一过程就十分繁琐了(选中字符串->复制->再选中未命名函数->n(rename global item)->黏贴->回车),为了能够节约这么一步骤,我就突发奇想是不是能够开发一个插件来减少其中的步骤,快速进行函数重命名操作呢?FRC的设计初衷就是这了。 需求分析 作为一个半吊子的ida插件设计者,大致整理了一下插件需要实现的功能: 通过快捷键实现字符串的复制 通过快捷键实现函数的重命名操作 接着就对这两个方向进行分析。 相关资料我本人也不是特别抗拒使用GPT来进行开发,但是会觉得GPT加快了获取结果的进度,而过程的处理变得有些不动🧠了,所以在插件实现的过程中多查阅相关资料还是很有必要的。 idc_api:IDC API 参考...
安卓手机刷入Kali Nethunter
Kali Nethunter因为最近在准备捣鼓设备,打算给手机里安装些工具,恰好手头有一部闲置的手机(而且贬值严重,四五年前的机子已经贬值到三分之一不到了),就顺便来刷机装个Nethunter作为一部移动端的攻击设备使用。 而且看到好多师傅用来bad usb攻击,自己也想着效仿一下,于是就准备刷入该系统。 分享一些我在刷机过程中遇到的一些优质文章: 介绍Nethunter大部分工具:安装 Kali NetHunter (完整版、精简版、非root版)、实战指南、ARM设备武器化指南、andrax、安卓渗透drozer-CSDN博客 刷机入门:使用OnePlus 6T(一加6T)刷入 Kali NetHunter的操作总结 - Junglezt - 博客园 unlocktoo刷取oppo:oppo a53 5g unlocktool 强解bl锁,magisk工具root 先知社区 设备信息手机型号:OPPO A72 5G 处理器:天玑720八核 型号:PDYM20 ColorOS版本:V12.1 安卓版本:12 点击版本信息 ->...
gdb_tips
前言学长推荐了个有趣的github项目,就此来回顾学习一下gdb的调试技巧:100-gdb-tips/src/index.md at master · hellogcc/100-gdb-tips 信息显示显示gdb版本信息1234gdb --versiongdb -v# 显示正在运行的 GDB 版本。您应该将此信息包含在 GDB 错误报告中。如果您的站点使用多个版本的 GDB,您可能需要确定正在运行的 GDB 版本;随着 GDB 的发展,新的命令被引入,旧的命令可能会消失。此外,许多系统供应商提供了 GDB 的变体版本,并且 GNU/Linux 发行版中也有 GDB 的变体版本。版本号与启动GDB时公布的版本号相同。# 目前只接触到gdb版本会和python版本存在一定兼容性问题 而一些插件又依赖于python版本,所以会导致gdb版本低会安装不了插件 显示gdb版权相关信息12pwndbg> show/info copying #gdb权限信息pwndbg> show/info warranty ...
ctfshow_pwn_181_204
前言这段时间没搞过pwn了,发现ctfshow wp更新了,那就来学一下吧😋(绝对不是这个原因🙅) 随缘更~~ 181–ret2text直接就是栈溢出了 能覆盖返回地址三字节 函数表里面有个Mid函数读flag,直接返回即可 123456789101112131415161718#coding:utf-8from tw11ty import *#from ctypes import *if __name__ == '__main__' : # context.log_level = 'info' IPort = 'pwn.challenge.ctf.show 28220' pwnfile = './181' libc_name = '/lib/x86_64-linux-gnu/libc.so.6' elf = ELF(pwnfile) io = init(pwnfile, IPort, libc_name) #...
WKCTF-pwn
baby_stackwait函数里面有个格式化字符串,多试几次能试出来offset=20时拿到libc v2长度为256字节,此函数中的a1[256]会造成栈上的off by null 布置的payload,rbp每次低字节为00 可以用ret填,不过exp多打几次出了 1234567891011121314151617181920212223242526272829303132333435363738#coding:utf-8from pwn import *from tw11ty import *#from ctypes import *if __name__ == '__main__' : # context.log_level = 'info' IPort = '110.40.35.73 33750' pwnfile = './pwn' libc_name =...
arm-pwn入门
一些师傅的博客: 关于学习arm架构下的pwn的总结 - ZikH26 - 博客园 (cnblogs.com) arm pwn 入门 | blingbling’s blog (blingblingxuanxuan.github.io) IOT pwn_apt install mips-linux-CSDN博客 [原创] CTF 中 ARM & AArch64 架构下的 Pwn-Pwn-看雪-安全社区|安全招聘|kanxue.com 也参考了许多其他师傅们的博客,这里不一一贴出来了。 最近刚好在看 《计算机组成原理( Alan Clements )》,以ARM体系架构为例,详细介绍其指令集、寄存器结构、指令执行流程等核心内容。对arm入门很有帮助。 目录- ARM寄存器集 - ARM指令集 - ARM PWN环境搭建 目录 ARM寄存器集 ARM指令集 ARM PWN环境搭建 题目一:32位 arm架构 静态 恢复符号表 题目二:32位 arm架构 动态 题目三:64位 aarch64架构 动态 题目四:32位 arm ret2libc 题目五:aarch64架构...
2024春秋杯夏季赛pwn
2024春秋杯夏季赛-pwnawdp没看,ctf只做出来两题,还有一题理论可行。 参考博客: https://starrysky1004.github.io/2024/07/05/2024-shu-qi-xue-xi-ji-lu/ 2024春秋杯WP - lmarch2 - 博客园 (cnblogs.com) 目录- stdout 解法一 解法二 解法三 - Shuffled_Execution - Save the preceniss 不可能的爆破… 正确解法 stdoutlibc版本:Ubuntu GLIBC 2.31-0ubuntu9.9 主函数溢出0x10字节,能覆盖到ret_addr;程序中有vuln函数,溢出 0x200-0x20 字节 初始化函数中 setvbuf(stdout, 0LL, 0, 0LL)设置为了标准输出无缓冲,setvbuf(stdin, 0LL, 2, 0LL)还是正常输出 12345int init(){ setvbuf(stdout, 0LL, 0, 0LL); return setvbuf(stdin,...
Iot-vulhub复现
借着逆向课的作业,就借此机会来简单学习并复现iot固件漏洞。网上搜集资料找到了Vu1nT0tal/IoT-vulhub: IoT固件漏洞复现环境 (github.com),感觉该项目对0基础入门iot固件漏洞复现是蛮有帮助的,就以此对相关漏洞进行复现。 由于我的服务器是国内的,所以构建过程会有很多麻烦,而且dockerhub也g了…… 目录- 环境构建 基础环境构建 漏洞环境构建 - TOTOLINK NR1800X (CVE-2022-41518) - Vivotek CC8160 栈溢出漏洞 - 华为 HG532 远程代码执行漏洞(CVE-2017-17215) - Cisco RV110W 远程代码执行漏洞(CVE-2020-3331) - D-Link DIR-859 命令注入漏洞(CVE-2019-17621) 本地仿真环境搭建 binwelk 固件解包工具 qemu Firmadyne 固件仿真工具 模拟运行固件 环境构建 IoT-vulhub 漏洞复现 – wsxk’s blog – 小菜鸡 IoT-Vulhub基础环境搭建 |...
2024ciscn分区赛-pwn复现
2024华东北分区赛-pwn复现第一次打国赛,也是第一次打awdp(非正规)。赛后平台、题目都是非预期。竟然可以用fix来break,算是长见识了。这次比赛更多的是积累经验了。 8web...
_IO_FILE基础利用
_IO_FILE利用 sky123师傅博客:http://t.csdnimg.cn/O8y8S,从IO_FILE的结构、原理到利用,写得极其详细易懂 hollk师傅:好好说话之IO_FILE利用(1):利用_IO_2_1_stdout泄露libc_libc泄露方式-CSDN博客 _IO_FILE结构 在2.31中定义在了struct_FILE.h头文件中 参照sky123师傅的贴图仿作出一幅IO_FILE结构关系图 1.FILE结构_IO_FILE结构在较低版本的libc中定义在glibc/libio/libio.h,较高版本定义在glibc/libio/bits\types\struct_FILE.h中,__IO_FILE结构体中存储缓冲区相关的成员变量。 _IO_list_all指向最后创建的FILE结构(初始化后指向__IO_2_1_stderr),各FILE结构通过_chain域链接形成一个单项链表。 _IO_FILE_plus中包含了_IO_FILE结构以及名为vtable的 _IO_jump_t...