开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 6952|回复: 25
打印 上一主题 下一主题
收起左侧

[易源码分享] [shellcode专题]便捷的内核shellcode一键生成工具源码,附教程

[复制链接]
跳转到指定楼层
楼主
发表于 2022-8-14 23:37:47 | 只看该作者 |只看大图 回帖奖励 |正序浏览 |阅读模式   江苏省南京市
分享源码
界面截图: -
是否带模块: 纯源码
备注说明: -
花了点时间写了个shellcode生成工具,原理很简单,使用起来也很简单,接下来开贴教程驱动应该怎么设置,代码应该怎么编写。(PS:编写驱动需要wdk,请到官网下载)
VS项目设置:
属性->C/C++->常规->将警告视为错误-否
属性->C/C++->代码生成->安全检查-禁用GS安全检查
属性->C/C++->代码生成->控制流防护-否
属性->链接器>高级->入口点设置为你的驱动入口函数,不要使用默认的FxDriverEntry
驱动代码皆为x64,以zczc表回调为例,编写shellcode
入口函数:

zc回调函数:

回调函数:

函数声明:

卸载函数:

函数命名一定要像我这样,目的是让编译器将你的函数按照我们想要的顺序编译,编写完函数编译驱动文件。
打开IDA,载入刚刚编译的驱动文件,你的IDA左边显示成这样才可以使用我的shellcode工具,如果出现一大堆函数是不行的

IDA打开64位PE文件的jz都是0x140001000开始,从IDA里面我们可以看到a_RegisterCallback函数的入口地址是0x140001038,我们记录下来0x38,
a_RegisterCallback里面取了回调函数地址,也就是这段汇编:

跟过去找到这个函数,记录函数结束地址,这里我们记录结束地址+0x1,也就是0x14000108B,记录0x8B

记录完成后打开cmd,进入shellcode生成工具目录,使用方法是KShell.exe 驱动文件名,输入我们刚才记录的入口和结束地址,也就是0x38和0x8B

回车生成:

生成的shellcode保存在同目录下,记住起始地址和结束地址一定要像我那样,不然会出现ERROR。生成了两个文件,一个bin一个txt,bin文件是专门给加载器用的,这里我们不需要用到,打开txt文件,全部复制下来

最后两行就是我们用到的内核函数地址,接下来实现shellcode的执行。


编译驱动,加载驱动:

路径显示为空,简单的shellcode就是这样的,如果是复杂的代码,可能会出错,请用IDA仔细核对函数调用地址。
为什么要用shellcode呢?占用小,运行速度快,不易察觉,如果对shellcode进行加密简直无法无天。
工具拓展:jmp,相对地址函数的call...
附件源码: KShell.rar (20.28 KB, 下载次数: 136)
源码有错误地方请联系我改正!

评分

参与人数 10好评 +9 精币 +22 收起 理由
a5598869 + 3 易语言里用黑月编译器是不是效果相同啊啊
机智蛋 + 1 + 1 新技能已get√
司徒西 + 1 + 2 支持开源~!感谢分享
易语言资源网 + 1 + 5 开源精神必须支持~
猫神父 + 1 + 2 支持开源~!感谢分享
CAMPS + 1 + 1 支持开源~!感谢分享
hipxh + 1 + 1 糟糕,他真的想教会我们!
九亿少女的梦Xbl + 1 + 2 支持开源~!感谢分享
冰点 + 1 + 5 感谢分享,很给力!~
a524666979 + 1 已经无法无天了

查看全部评分


签到天数: 1 天

26
发表于 2025-1-1 14:39:18 | 只看该作者   福建省泉州市
感谢大佬分享
回复 支持 反对

使用道具 举报

结帖率:90% (9/10)

签到天数: 3 天

25
发表于 2024-6-1 10:59:21 | 只看该作者   山东省青岛市
ShellCode技术是很高深的技术了 我这样的小白 完全看不懂!
回复 支持 反对

使用道具 举报

24
发表于 2023-8-25 09:16:37 高大上手机用户 | 只看该作者   广东省中山市
支不支持x86
回复 支持 反对

使用道具 举报

结帖率:92% (49/53)

签到天数: 4 天

23
发表于 2023-1-28 11:56:06 | 只看该作者   江西省上饶市
        糟糕,他真的想教会我们!
回复 支持 反对

使用道具 举报

22
发表于 2022-10-15 16:08:50 | 只看该作者   美国
所以我想问一下 怎么加密shellcode
回复 支持 反对

使用道具 举报

签到天数: 9 天

21
发表于 2022-8-18 13:14:34 | 只看该作者   江苏省连云港市
感谢分享
回复 支持 反对

使用道具 举报

结帖率:93% (13/14)

签到天数: 9 天

20
发表于 2022-8-17 22:23:11 | 只看该作者   广西壮族自治区崇左市
这个是不是和硬编码一样不兼容全系统?
回复 支持 反对

使用道具 举报

19
 楼主| 发表于 2022-8-17 13:49:23 | 只看该作者   江苏省南京市
小伟呀 发表于 2022-8-17 03:30
这个帖子不错,方式不错,不过我想请问一下,如果有全局变量之类的,怎么写进shellcode里面 ...

shellcode不能使用全局变量,可以用参数传进去
回复 支持 反对

使用道具 举报

18
发表于 2022-8-17 03:30:47 | 只看该作者   河南省鹤壁市
这个帖子不错,方式不错,不过我想请问一下,如果有全局变量之类的,怎么写进shellcode里面
回复 支持 反对

使用道具 举报

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

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报QQ: 793400750,邮箱:[email protected]
网站简介:精易论坛成立于2009年,是一个程序设计学习交流技术论坛,隶属于揭阳市揭东区精易科技有限公司所有。
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

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