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

0 條評論,你可以發表評論,我們會進行改進
Comment author placeholder