在密碼學中,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