Linux内核分析——程序破解
1、 掌握NOP、JNE、JE、JMP、CMP汇编指令的机器码
NOP:NOP指令即“空指令”。执行到NOP指令时,CPU什么也不做,仅仅当做一个指令执行过去并继续执行NOP后面的一条指令。(机器码:90)
JNE:条件转移指令,如果不相等则跳转。(机器码:75)
JE:条件转移指令,如果相等则跳转。(机器码:74)
JMP:无条件转移指令。段内直接短转Jmp short(机器码:EB) 段内直接近转移Jmp near(机器码:E9) 段内间接转移 Jmp word(机器码:FF) 段间直接(远)转移Jmp far(机器码:EA)
CMP:比较指令,功能相当于减法指令,只是对操作数之间运算比较,不保存结果。cmp指令执行后,将对标志寄存器产生影响。其他相关指令通过识别这些被影响的标志寄存器位来得知比较结果。
2、掌握反汇编与十六进制编程器
(1)编写和编译程序


代码功能:输入密码与预存密码进行比对,正确输出right,否则输出wrong。
(2)通过反汇编求出用户名、密码
打开终端,输入objdump –d hello,找到main函数:
(objdump是gcc工具,用来查看编译后目标文件的组成)


注意标记的jne命令,表示在前面的cmp指令比较结果为不相等时跳转,cmp指令比较的值即原本密码和输入的值,
当两者不等时跳转4005f0输出wrong,否则继续执行下一条指令输出right,
(3)修改可执行文件,玩转密码登陆
①不管输入正确与否都可以正常登陆。
要实现不相等时也输出right,只需修改跳转地址,即修改该条指令为7500
用vi打开该可执行文件,使用%!xxd命令16进制显示
然后使用/750e指令查找制定代码,如果无法搜索到则在中间加空格子/75 0e

找到修改位置

将0c改为00:然后输入:%!xxd –r

然后使用:%!xxd -r命令还原成二进制,最后:wq保存即可

下面是将修改后的文件反汇编的结果

测试结果:(无论输入密码正确与否,都表示正确)

②不可以正常登陆,即需要无条件跳转到错误的地方,无条件跳转为jmp,则同理需要将750c改成eb0c.(eb为无条件跳转);
测试结果:(输入正确,表示错误)

下面是修改后反汇编的结果

测试结果:(输入正确密码,显示不正确)

③输入正确密码不能登录,输入错误密码能够登陆。
则需要将其改为740c(je相等时跳转,不相等时继续执行)




Linux内核分析——程序破解的更多相关文章
- linux内核分析程序破解实践报告
 - linux内核分析作业:以一简单C程序为例,分析汇编代码理解计算机如何工作
		
一.实验 使用gcc –S –o main.s main.c -m32 命令编译成汇编代码,如下代码中的数字请自行修改以防与他人雷同 int g(int x) { return x + 3; } in ...
 - 20135239益西拉姆  Linux内核分析 汇编一个简单的c程序并分析其指令过程
		
益西拉姆+<Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 第一周linux内核分析 学习笔记 一.计算机 ...
 - Linux内核分析第二周学习总结:操作系统是如何工作的?
		
韩玉琪 + 原创作品转载请注明出处 + <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 一.函数调用堆栈 ...
 - linux内核分析作业8:理解进程调度时机跟踪分析进程调度与进程切换的过程
		
1. 实验目的 选择一个系统调用(13号系统调用time除外),系统调用列表,使用库函数API和C代码中嵌入汇编代码两种方式使用同一个系统调用 分析汇编代码调用系统调用的工作过程,特别是参数的传递的方 ...
 - Linux内核分析作业7:Linux内核如何装载和启动一个可执行程序
		
1.可执行文件的格式 在 Linux 平台下主要有以下三种可执行文件格式: 1.a.out(assembler and link editor output 汇编器和链接编辑器的输出) ...
 - linux内核分析作业:操作系统是如何工作的进行:完成一个简单的时间片轮转多道程序内核代码
		
计算机如何工作 三个法宝:存储程序计算机.函数调用堆栈.中断机制. 堆栈 函数调用框架 传递参数 保存返回地址 提供局部变量空间 堆栈相关的寄存器 Esp 堆栈指针 (stack pointer) ...
 - linux内核分析作业4:使用库函数API和C代码中嵌入汇编代码两种方式使用同一个系统调用
		
系统调用:库函数封装了系统调用,通过库函数和系统调用打交道 用户态:低级别执行状态,代码的掌控范围会受到限制. 内核态:高执行级别,代码可移植性特权指令,访问任意物理地址 为什么划分级别:如果全部特权 ...
 - linux实践之程序破解
		
linux实践之程序破解 这次的实践是文件破解,让我们从login可执行文件开始吧! 首先我们执行一下这个可执行程序 ①我们希望在不知道密码的情况下,能够登陆进去.且无论密码是什么,都是提示“on y ...
 
随机推荐
- apache的php模块讲解以及搭建phpmyadmin管理数据库mysql
			
1.php php的包名字叫做php-common,其配置文件使用的是ini风格的格式. php的配置文件以分号作为注释,把分号去掉表示启动此片段功能. 在这里我们可以看到php在apache中的模块 ...
 - Alpha冲刺! Day7 - 砍柴
			
Alpha冲刺! Day7 - 砍柴 今日已完成 晨瑶:列了各模块目前的进度情况:确定了纯多媒体流星预览页的显示方式:给工具包函数列表新增了与服务器端的交互:玩华为软件云发现刚好可以试试它的测试,于是 ...
 - springboot 传值到页面
			
每天学习一点点 编程PDF电子书.视频教程免费下载:http://www.shitanlife.com/code <!DOCTYPE html> 2 <html> 3 &l ...
 - Vue:渲染、指令、事件、组件、Props
			
每天学习一点点 编程PDF电子书免费下载: http://www.shitanlife.com/code 如果要我用一句话描述使用 Vue 的经历,我可能会说“它如此合乎常理”或者“它提供给我需要的工 ...
 - Excel各种条件求和的公式汇总
			
经常和Execl打交道的人肯定觉得求和公式是大家时常用到的.Excel里有哪几路求和公式呢?他们的使用方式又是怎样?我为大家汇总一下. 使用SUMIF()公式的单条件求和: 如要统计C列中的数据,要求 ...
 - 433 模块 ARDUINO测试
			
实验硬件 发射端 Arduino + 433超外差发射机 高,低电平和悬空三种模式切换 由简单的官方库修改 /* This is a minimal sketch without using ...
 - MP实战系列(六)之代码生成器讲解
			
MP的代码生成器可谓用"简洁"二字,来形容. 我个人觉得jeesite的代码生成器都不一定比它好用.当然也是由于我个人的习惯. 只需一键执行main方法,就可以生成对应的项目文件, ...
 - [转]Python shutil 模块
			
转自: https://www.cnblogs.com/wuzhiblog/p/6535527.html https://www.cnblogs.com/caibao666/p/6433864.htm ...
 - WaitForSingleObject的详细用法
			
在多线程的情况下,有时候我们会希望等待某一线程完成了再继续做其他事情,要实现这个目的,可以使用Windows API函数WaitForSingleObject,或者WaitForMultipleObj ...
 - centos7环境搭建
			
1. tar命令安装 yum install -y tar 2. jdk8下载 wget --no-check-certificate --no-cookies --header "Cook ...