在密碼學(xué)中,Caesar 密碼是一個最簡單的已知的加密技術(shù)。在該方法中,以被加密的數(shù)據(jù)中的每個字母被替換下來的字母跟一些固定的位置數(shù)。
在這個例子中,讓我們通過簡單地更換每個字母,其具有移位的兩個字母中的數(shù)據(jù)進(jìn)行加密,因此,c, b將被d取代。
我們使用LODS,加載的原始字符串'password'入內(nèi)存。
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
上面的代碼編譯和執(zhí)行時,它會產(chǎn)生以下結(jié)果:
rcuuyqtf