位置:首页 » 文章/教程分享 » 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