热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

逆向菜鸡实战破解思科模拟器登录限制

发现居然跳过了登录窗口;这时可以发现CPU窗口跳转那条线变红接着直接F9运行;发现有以下两个字符串瞬间明白肯定是有对ollydbg的反调试;在两个跳转处下上断点;过滤名字就是一种思

当我们想要破解一个软件时,个人认为最重要的就是对它的关键代码进行定位(ps:这里的关键代码是相对于我们而言的,比如想要去掉软件的启动页广告,其中一个思路时可以找到它加载的地方。分析一下,判断哪里判断是否启动页加载的逻辑改掉它就好啦。)                                                                                                                     

 1、背景:因为学的专业开设有路由交换这门课,但是呢,每次启动都有一个烦人的登录页每次都是选择游客模式,这不是最关键,关键就是必须等待15秒才可以进入百度谷歌了一波,居然找不到破解版,也没找到任何相关教程,心里有点凉不过作为一个逆向菜鸡,真的是忍不了(ps:好久没实战破解过了,拿来练练手也不错嘛)

2、破解时用到的:环境(学校用的版本是6.3,我用的win10x64位系统),工具(PEiD,IDA Pro, Pexplorer,Olydbg,Spy++,x32dbg),方法(单步跟踪,各种回溯,各种断点等等),咳咳,最重要的就是眼手不能停,其他版本大家自己尝试

3、最后想要实现:就是跳过等待时间,直接进入模拟器,最好是可以直接去除Nag(登陆页面)

4、简单说下过程:本例中采用最简单的思路,就是查找关键字符串,首先观察下这个页面能挖出什么信息,这里我主要就是利用这三个字符串

软件很大IDA对于我这种菜鸡也派不上用场,而且加载和OD一样贼慢;这里我选用x32dbg:反汇编窗口右键,选择字符串,所有模块

我先过滤了一下ollydbg,这里就是过滤关键字符;

发现有以下两个字符串瞬间明白肯定是有对ollydbg的反调试:发现有ollydbg,结用ollydbg没办法动态调试,就是软件的反调试机制,有些公司会专门针对反编译软件做反调试看一个程序有没有对你的反编译软件做处理,过滤名字就是一种思路

难怪用ollydbg没办法进行动态调试(ps:这里没有仔细研究是怎么做的,不是本文重点)

再过滤一下Login,发现有GuessLogin,还有一些网址之类的;本来想到可以直接从网址入手,但是不行,这个网址只是用来与服务器交互的。

我本来就不想登陆账号

向下翻就突然发现set loginbanner之类的,心想banner不是那个横幅什么的嘛,下了断点,去试试

找到断首,逐行向下单步分析,结果发现没什么用。。。

又回到字符串那里,乖乖的把所有的GuestLogin下上了断点;调试到这里的时候,突然GuestLogin那个按钮变灰并出现了15;这时候心里非常开心,以为附近就是关键点,这样就可以跳过这个计时器或者改变数值15为0,结果调试着调试着我就乱了

不知道程序执行到哪了,单步了估计300次,不变14。。。

然后重新载入,有些觉得和这个没啥关系的call直接跳过(ps:好多可以根据注释还有名字来判断它的作用)

单步着,单步着,突然发现15变成14了,单步向下时多次在下面这两个跳转直间来回跳,将上面那个je跳转双击改成jmp之后F9运行两次,发现按钮上面的字符变了,从Guest变成了Gue:

接着13,可以看到我将je跳转还原之后,又变成了Gues

这里简单解释一下:在两个跳转处下上断点,单步几次就会发现5055C500地址处是取我们的字符串GuestLogin(的,而控制的正是这两个跳转。

12了:

然后发现注释窗口出现了“Time:%1“这样的字符串:这个字符串是在注释窗口中出现的,一般在的动态调试的过程中,都会出现类似的提示性的字符,time就是时间,那代表处理时间的逻辑可能被触发了。

想着这不是跟时间有关嘛,那这个倒计时处理函数肯定也在附近(ps:这时候一直在找这个函数所在位置)

接着

又出现了一个“2timeout()“,不知道何方神圣,继续单步

调试到这里的时候,发现了GuestLogin(11),就想着给它下一个内存断点

右键选择,在内存窗口中转到双字

右键设置硬件访问断点(Dword)

到这里就彻底凌乱了,程序一个劲儿的暂停,不是异常就是内存短点;后来想着是不是太长了,就重新删除,又只在11处下断点;结果还是一样,因为单步操作的快捷键是F8,所以我键盘的F8要炸了;鼠标点击也可以单步,手指也有点凉。

好吧,到这里都要打算放弃了,因为机房9.30就锁门了,回宿舍的路上感觉好不甘心呀,又想了想是不是思路有问题,换种思路行不行;一直都在想办法找到控制倒计时的地方,那可不可以直接在加载这个登陆页面的地方搞一下呢,回到宿舍后,立即进入状态,重新载入,回到断点窗口

双击进入

向上翻,发现全都是一些初始化的信息,猜测是不是Nag(登陆窗口也会在这里初始化)

后来发现这附近就这一个可能的跳转,心想着试试吧,不行就洗洗睡了;修改下ZF标志位的值使得je跳转成立。

方法:右侧寄存器窗口,双击ZF后面的0使他变成1就可以,这时可以发现CPU窗口跳转那条线变红

接着直接F9运行,发现居然跳过了登录窗口,直接进入主程序了,开心

好的,我们既然已经知道了这个je是决定时是否加载登录窗口的关键跳转;那我们将这里双击修改成jmp

接着选中被修改的部分(ps:这里可以多选)

Ctrl+ P打开补丁窗口,点击修补文件,选择你想要修补的源程序(ps:这里大家可以先备份下,这样的话修改出错能够及时恢复)

总结一下:本来是想要改判断倒计时的逻辑,结果不成,但是可以找到加载登录窗口的地方,改这里同样可以达到效果;修改的地方就这一处就好,但是调试过程非常麻烦,需要大量时间,我用了好几个小时才成功,其实还是太菜了,肯定有更简单的方法,希望有师傅可以指点一下,还有就是分析过程肯定错误不少,希望可以指出,感激不尽。

声明

文章仅用于普及网络安全知识,提高小伙伴的安全意识的同时介绍常见漏洞的特征等,若读者因此作出危害网络安全的行为后果自负,与合天智汇以及原作者无关,特此声明!

记得投稿哦

如果有好的技术原创文章

欢迎投稿至邮箱:edu@heetian.com

合天会根据时效、新颖程度、文笔及实用性等要素对文章进行评判,一经发布给予100元-500元不等的稿费

还等什么呢?有才能的你快来投稿吧!

了解更多详情点击重金悬赏 | 合天原创投稿等你来!


推荐阅读
  • 如何提高PHP编程技能及推荐高级教程
    本文介绍了如何提高PHP编程技能的方法,推荐了一些高级教程。学习任何一种编程语言都需要长期的坚持和不懈的努力,本文提醒读者要有足够的耐心和时间投入。通过实践操作学习,可以更好地理解和掌握PHP语言的特异性,特别是单引号和双引号的用法。同时,本文也指出了只走马观花看整体而不深入学习的学习方式无法真正掌握这门语言,建议读者要从整体来考虑局部,培养大局观。最后,本文提醒读者完成一个像模像样的网站需要付出更多的努力和实践。 ... [详细]
  • 本文介绍了Python高级网络编程及TCP/IP协议簇的OSI七层模型。首先简单介绍了七层模型的各层及其封装解封装过程。然后讨论了程序开发中涉及到的网络通信内容,主要包括TCP协议、UDP协议和IPV4协议。最后还介绍了socket编程、聊天socket实现、远程执行命令、上传文件、socketserver及其源码分析等相关内容。 ... [详细]
  • Java序列化对象传给PHP的方法及原理解析
    本文介绍了Java序列化对象传给PHP的方法及原理,包括Java对象传递的方式、序列化的方式、PHP中的序列化用法介绍、Java是否能反序列化PHP的数据、Java序列化的原理以及解决Java序列化中的问题。同时还解释了序列化的概念和作用,以及代码执行序列化所需要的权限。最后指出,序列化会将对象实例的所有字段都进行序列化,使得数据能够被表示为实例的序列化数据,但只有能够解释该格式的代码才能够确定数据的内容。 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 图解redis的持久化存储机制RDB和AOF的原理和优缺点
    本文通过图解的方式介绍了redis的持久化存储机制RDB和AOF的原理和优缺点。RDB是将redis内存中的数据保存为快照文件,恢复速度较快但不支持拉链式快照。AOF是将操作日志保存到磁盘,实时存储数据但恢复速度较慢。文章详细分析了两种机制的优缺点,帮助读者更好地理解redis的持久化存储策略。 ... [详细]
  • 众筹商城与传统商城的区别及php众筹网站的程序源码
    本文介绍了众筹商城与传统商城的区别,包括所售产品和玩法不同以及运营方式不同。同时还提到了php众筹网站的程序源码和方维众筹的安装和环境问题。 ... [详细]
  • RouterOS 5.16软路由安装图解教程
    本文介绍了如何安装RouterOS 5.16软路由系统,包括系统要求、安装步骤和登录方式。同时提供了详细的图解教程,方便读者进行操作。 ... [详细]
  • 嵌入式处理器的架构与内核发展历程
    本文主要介绍了嵌入式处理器的架构与内核发展历程,包括不同架构的指令集的变化,以及内核的流水线和结构。通过对ARM架构的分析,可以更好地理解嵌入式处理器的架构与内核的关系。 ... [详细]
  • 本文介绍了操作系统的定义和功能,包括操作系统的本质、用户界面以及系统调用的分类。同时还介绍了进程和线程的区别,包括进程和线程的定义和作用。 ... [详细]
  • MySQL数据库锁机制及其应用(数据库锁的概念)
    本文介绍了MySQL数据库锁机制及其应用。数据库锁是计算机协调多个进程或线程并发访问某一资源的机制,在数据库中,数据是一种供许多用户共享的资源,如何保证数据并发访问的一致性和有效性是数据库必须解决的问题。MySQL的锁机制相对简单,不同的存储引擎支持不同的锁机制,主要包括表级锁、行级锁和页面锁。本文详细介绍了MySQL表级锁的锁模式和特点,以及行级锁和页面锁的特点和应用场景。同时还讨论了锁冲突对数据库并发访问性能的影响。 ... [详细]
  • 初识java关于JDK、JRE、JVM 了解一下 ... [详细]
  • Android中高级面试必知必会,积累总结
    本文介绍了Android中高级面试的必知必会内容,并总结了相关经验。文章指出,如今的Android市场对开发人员的要求更高,需要更专业的人才。同时,文章还给出了针对Android岗位的职责和要求,并提供了简历突出的建议。 ... [详细]
  • 本文详细介绍了云服务器API接口的概念和作用,以及如何使用API接口管理云上资源和开发应用程序。通过创建实例API、调整实例配置API、关闭实例API和退还实例API等功能,可以实现云服务器的创建、配置修改和销毁等操作。对于想要学习云服务器API接口的人来说,本文提供了详细的入门指南和使用方法。如果想进一步了解相关知识或阅读更多相关文章,请关注编程笔记行业资讯频道。 ... [详细]
  • Metasploit攻击渗透实践
    本文介绍了Metasploit攻击渗透实践的内容和要求,包括主动攻击、针对浏览器和客户端的攻击,以及成功应用辅助模块的实践过程。其中涉及使用Hydra在不知道密码的情况下攻击metsploit2靶机获取密码,以及攻击浏览器中的tomcat服务的具体步骤。同时还讲解了爆破密码的方法和设置攻击目标主机的相关参数。 ... [详细]
  • 预备知识可参考我整理的博客Windows编程之线程:https:www.cnblogs.comZhuSenlinp16662075.htmlWindows编程之线程同步:https ... [详细]
author-avatar
攻玉是我_944
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有