Na criptografia, uma cifra de César é uma das técnicas de criptografia conhecidas mais simples. Neste método, cada letra nos dados a serem criptografados é substituída por uma letra com algum número fixo de posições abaixo do alfabeto.
Neste exemplo, vamos criptografar os dados simplesmente substituindo cada alfabeto por uma mudança de dois alfabetos, então a será substituído por c, b com d e assim por diante.
Usamos LODS para carregar a string original 'senha' na memória.
section .text
global _start ;must be declared for using gcc
_start: ;tell linker entry point
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
Quando o código acima é compilado e executado, ele produz o seguinte resultado:
rcuuyqtf