基于元神操作系统编程读取硬盘文件

2024-09-06 16:36

本文主要是介绍基于元神操作系统编程读取硬盘文件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 背景

本文介绍了在元神操作系统上读取硬盘文件的方法,示例所用的硬盘是NTFS文件系统的、有2个分区的硬盘。

2. 方法

(1)编写程序

本例通过调用元神操作系统的API来读取指定文件的内容,并以二进制数据(十六进制格式)的形式打印到屏幕上,代码如下所示:

use32START:pushacall demo_read_disk_filepopairetinclude 'api_def.inc'OS_API equ 0x00030C16
API_PARAM equ 0x03000000
SEG_BASE equ 0x00040000
cursor_x equ 0x02004B10
cursor_y equ 0x02004B12sector_buff: times 512 db 0
file_name_disk db 'd1:\test0.txt',0
demo_read_disk_file:pushamov edi, API_PARAMmov dword [fs:edi], API_READ_DISK_FILEmov dword [fs:edi+4], 2		;2 parametersxor eax, eaxmov ax, dsadd eax, SEG_BASEmov bh,byte [fs:eax+7]mov bl,byte [fs:eax+4]shl ebx,16mov bx,word [fs:eax+2]mov eax, ebxadd ebx, file_name_diskadd eax, sector_buffmov dword [fs:edi+8], ebx	;parameter_1: file namemov dword [fs:edi+12], eax	;parameter_2: start address of buffer to store resultcall pword [fs:OS_API]mov eax, [fs:edi+8]movzx ebx, word [fs:cursor_y]movzx ecx, word [fs:cursor_x]mov esi, [fs:edi+12]call print_bytes_hexadd word [fs:cursor_y], 2poparet;print hex bytes
;input:
;	eax: byte count to print
;	ebx: y coordinate to print (from 0)
;	ecx: x coordinate to print (from 0)
;	esi: buffer storing data to print
print_bytes_hex:pushaimul edi,ebx,80*2add edi,ecxadd edi,ecxmov ecx,eaxmov ah,0x0F.next_char:mov bl,byte [fs:esi].hex_char:mov al,bland al,0x0Fadd al,0x30cmp al,0x39jbe .num_charadd al,'A'-0x30-10.num_char:mov [gs:edi+2],axshr ebx,4mov al,bland al,0x0Fadd al,0x30cmp al,0x39jbe .num_char2add al,'A'-0x30-10.num_char2:mov [gs:edi],axmov al,' 'mov [gs:edi+4],axadd edi,6inc esiloop .next_charpoparet

代码中先对系统调用参数进行设置:第一个参数的API类型设置为API_READ_DISK_FILE,表示读取硬盘文件;第二个参数设置为2,表示该API需要两个输入参数;第三个参数为要读取的文件名称,传入的是绝对文件路径的起始地址;第四个参数为存放文件内容的内存区起始地址,本例使用预定义的变量sector_buff,若要动态申请内存来存放文件内容,可以通过调用元神操作系统的API (API_ALLOC_MEMORY)来获取动态内存的起始地址,并将该地址作为参数进行设置。

设置好调用参数后通过call指令进行调用,获取目标文件的大小和内容,并将结果以十六进制序列的形式输出到屏幕上。此处文件的大小以字节为单位。

本例中的API类型定义如下:

API_READ_DISK_FILE	equ	0x00000006

备注:本例中的文件名称为绝对路径文件名,包含着完整的路径和文件名称,开头的第一个字母D表示该文件位于硬盘(disk)上,第二个字母1表示该文件在硬盘的第一个分区上,依此类推。

(2)运行程序

将上述代码保存为demo.asm文件,用FASM编译该文件生成二进制文件demo.bin,并将文件复制到装有元神操作系统的U盘的根目录,用该U盘启动进入元神操作系统,通过命令ZX执行该二进制文件,结果如下图所示:

本例中的硬盘文件test0.txt仅包含17个字符“1234567890ABCDEFG”,因此只显示了17个字节。若想以字符形式显示文件内容,可以自行编写程序替换print_bytes_hex函数。

3. 总结

本文示例程序通过元神操作系统的API调用来读取硬盘上的文件。文件名称以绝对路径的形式提供,包含着完整的路径;而保存文件内容的内存块可以使用预定义的缓冲区变量,也可以动态申请获得。读取硬盘文件的API调用返回了文件内容及其长度,之后可以根据自己的需要和文件格式来输出或操作文件内容。

这篇关于基于元神操作系统编程读取硬盘文件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1142536

相关文章

MySQL的JDBC编程详解

《MySQL的JDBC编程详解》:本文主要介绍MySQL的JDBC编程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、前置知识1. 引入依赖2. 认识 url二、JDBC 操作流程1. JDBC 的写操作2. JDBC 的读操作总结前言本文介绍了mysq

Python异步编程之await与asyncio基本用法详解

《Python异步编程之await与asyncio基本用法详解》在Python中,await和asyncio是异步编程的核心工具,用于高效处理I/O密集型任务(如网络请求、文件读写、数据库操作等),接... 目录一、核心概念二、使用场景三、基本用法1. 定义协程2. 运行协程3. 并发执行多个任务四、关键

使用Java读取本地文件并转换为MultipartFile对象的方法

《使用Java读取本地文件并转换为MultipartFile对象的方法》在许多JavaWeb应用中,我们经常会遇到将本地文件上传至服务器或其他系统的需求,在这种场景下,MultipartFile对象非... 目录1. 基本需求2. 自定义 MultipartFile 类3. 实现代码4. 代码解析5. 自定

AOP编程的基本概念与idea编辑器的配合体验过程

《AOP编程的基本概念与idea编辑器的配合体验过程》文章简要介绍了AOP基础概念,包括Before/Around通知、PointCut切入点、Advice通知体、JoinPoint连接点等,说明它们... 目录BeforeAroundAdvise — 通知PointCut — 切入点Acpect — 切面

MySQL 数据库表操作完全指南:创建、读取、更新与删除实战

《MySQL数据库表操作完全指南:创建、读取、更新与删除实战》本文系统讲解MySQL表的增删查改(CURD)操作,涵盖创建、更新、查询、删除及插入查询结果,也是贯穿各类项目开发全流程的基础数据交互原... 目录mysql系列前言一、Create(创建)并插入数据1.1 单行数据 + 全列插入1.2 多行数据

C#异步编程ConfigureAwait的使用小结

《C#异步编程ConfigureAwait的使用小结》本文介绍了异步编程在GUI和服务器端应用的优势,详细的介绍了async和await的关键作用,通过实例解析了在UI线程正确使用await.Conf... 异步编程是并发的一种形式,它有两大好处:对于面向终端用户的GUI程序,提高了响应能力对于服务器端应

C# async await 异步编程实现机制详解

《C#asyncawait异步编程实现机制详解》async/await是C#5.0引入的语法糖,它基于**状态机(StateMachine)**模式实现,将异步方法转换为编译器生成的状态机类,本... 目录一、async/await 异步编程实现机制1.1 核心概念1.2 编译器转换过程1.3 关键组件解析

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

Python使用openpyxl读取Excel的操作详解

《Python使用openpyxl读取Excel的操作详解》本文介绍了使用Python的openpyxl库进行Excel文件的创建、读写、数据操作、工作簿与工作表管理,包括创建工作簿、加载工作簿、操作... 目录1 概述1.1 图示1.2 安装第三方库2 工作簿 workbook2.1 创建:Workboo