Nasm LODS指令

在密码学中,Caesar 密码是一个最简单的已知的加密技术。在该方法中,以被加密的数据中的每个字母被替换下来的字母跟一些固定的位置数。

在这个例子中,让我们通过简单地更换每个字母,其具有移位的两个字母中的数据进行加密,因此,c, b将被d取代。

我们使用LODS,加载的原始字符串’password’入内存。

section .text
   global _start ;must be declared for using gcc
_start:;tell linker entry bytekits
   movecx, len
   movesi, s1
   movedi, s2
loop_here:
   lodsb
   add al, 02
   stosb
   looploop_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
取消
感谢您的支持,我会继续努力的!
扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

Powered by bytekits.com,汇天下文字,成非凡梦想!!!