Assembly汇编 LODS指令
在密码学中,Caesar 密码是一个最简单的已知的加密技术。在该方法中,以被加密的数据中的每个字母被替换下来的字母跟一些固定的位置数。
在这个例子中,让我们通过简单地更换每个字母,其具有移位的两个字母中的数据进行加密,因此,c, b将被d取代。
我们使用LODS,加载的原始字符串'password'入内存。
section .text global _start ;must be declared for using gcc _start: ;tell linker entry yiibai mov ecx, len mov esi, s1 mov edi, s2 loop_here: lodsb add al, 02 stosb loop loop_here cld rep movsb mov edx,20 ;message length mov ecx,s2 ;message to write mov ebx,1 ;file descriptor (stdout) mov eax,4 ;system call number (sys_write) int 0x80 ;call kernel mov eax,1 ;system call number (sys_exit) int 0x80 ;call kernel section .data s1 db 'password', 0 ;source len equ $-s1 section .bss s2 resb 10 ;destination
上面的代码编译和执行时,它会产生以下结果:
rcuuyqtf