Accueil > > > REVELATEUR DE MOT DE PASSE (ENLÈVE LES ASTÉRISQUES)
REVELATEUR DE MOT DE PASSE (ENLÈVE LES ASTÉRISQUES)
Information sur la source
Description
C'est ma 1ere source en ASM sur ce site. Elle n'as pas de grande prétention, juste montrer 2 méthodes différentes de révéler un mot de passe cacher sous des astérisques. (Supprime les astérisque et affiche un MessageBox avec le texte) Il suffit de démarrer l'application, positionner le pointeur de sa souris sur la zone de texte où se trouve le mot de passe et attendre 5 seconde. On peut voir comment créer un timer, recuperer la position du pointeur, récupere le handle d'une fenêtre, ....
Source
- .386
- .model flat,stdcall
- option casemap:none
- include \masm32\include\windows.inc
- include \masm32\include\user32.inc
- includelib \masm32\lib\user32.lib
- include \masm32\include\kernel32.inc
- includelib \masm32\lib\kernel32.lib
-
- WinMain proto :DWORD,:DWORD,:DWORD,:DWORD
-
- .DATA
-
- ClassName db "PasswordReveler",0
- AppName db "PasswordReveler",0
- NullString db 0
- Titre db "Mot de passe",0
-
- .DATA?
- wc WNDCLASSEX <>
- msg MSG <>
- hInstance HINSTANCE ?
- Password db 256 dup(?)
- Cursor POINT <>
-
- .CODE
- start:
- invoke GetModuleHandle, NULL
- mov hInstance,eax
-
- ; Crée une fenêtre afin de pouvoir créer un Timer
-
- mov wc.cbSize,SIZEOF WNDCLASSEX
- mov wc.style, CS_HREDRAW or CS_VREDRAW
- mov wc.lpfnWndProc, OFFSET WndProc
- mov wc.cbClsExtra,NULL
- mov wc.cbWndExtra,NULL
- push hInstance
- pop wc.hInstance
- mov wc.hbrBackground,COLOR_WINDOW+1
- mov wc.lpszMenuName,NULL
- mov wc.lpszClassName,OFFSET ClassName
- invoke LoadIcon,NULL,IDI_APPLICATION
- mov wc.hIcon,eax
- mov wc.hIconSm,eax
- invoke LoadCursor,NULL,IDC_ARROW
- mov wc.hCursor,eax
- invoke RegisterClassEx, addr wc
- invoke CreateWindowEx,NULL, ADDR ClassName, ADDR AppName, WS_OVERLAPPEDWINDOW, CW_USEDEFAULT, CW_USEDEFAULT, CW_USEDEFAULT, CW_USEDEFAULT, NULL, NULL, hInstance, NULL
-
- .WHILE TRUE
- invoke GetMessage, ADDR msg,NULL,0,0
- .BREAK .IF (!eax)
- invoke TranslateMessage, ADDR msg
- invoke DispatchMessage, ADDR msg
- .ENDW
- mov eax,msg.wParam
- invoke ExitProcess, eax
-
-
- WndProc proc hWnd:HWND, uMsg:UINT, wParam:WPARAM, lParam:LPARAM
-
- .if uMsg == WM_CREATE
- Invoke SetTimer,hWnd,0,5000, 0 ;Crée un timer de 5 secondes
- .elseif uMsg == WM_TIMER
- invoke KillTimer, hWnd, 0 ;Detruit le timer
-
- invoke GetCursorPos, ADDR Cursor ;Récupère la position du pointeur
- invoke WindowFromPoint, Cursor.x,Cursor.y ;Récupère la fenêtre sous le pointeur
- mov ebx,eax
-
- ;1ere Méthode
-
- invoke SendMessageA, ebx, 204, 0, ADDR NullString ;Supprime les *
- invoke RedrawWindow, ebx, 0, 0, 1 ;Rafraichi la fenêtre
-
- ;2eme Méthode
-
- invoke GetWindowTextA, ebx, ADDR Password, 255 ;Récupère le texte dans la fenêtre
- mov [Password+eax], 0 ;Tronque le texte (GetWindowText retourne la longueur de la chaine)
- invoke MessageBox, hWnd, ADDR Password, ADDR Titre, 1000h ;Affiche le texte (1000h = MB_SYSTEMMODAL)
-
-
- invoke MessageBeep, -1 ;Emet un bip
-
- invoke ExitProcess,0 ;Kill le process
- .endif
-
- invoke DefWindowProc,hWnd,uMsg,wParam,lParam
-
- ret
-
-
- WndProc endp
-
- end start
.386
.model flat,stdcall
option casemap:none
include \masm32\include\windows.inc
include \masm32\include\user32.inc
includelib \masm32\lib\user32.lib
include \masm32\include\kernel32.inc
includelib \masm32\lib\kernel32.lib
WinMain proto :DWORD,:DWORD,:DWORD,:DWORD
.DATA
ClassName db "PasswordReveler",0
AppName db "PasswordReveler",0
NullString db 0
Titre db "Mot de passe",0
.DATA?
wc WNDCLASSEX <>
msg MSG <>
hInstance HINSTANCE ?
Password db 256 dup(?)
Cursor POINT <>
.CODE
start:
invoke GetModuleHandle, NULL
mov hInstance,eax
; Crée une fenêtre afin de pouvoir créer un Timer
mov wc.cbSize,SIZEOF WNDCLASSEX
mov wc.style, CS_HREDRAW or CS_VREDRAW
mov wc.lpfnWndProc, OFFSET WndProc
mov wc.cbClsExtra,NULL
mov wc.cbWndExtra,NULL
push hInstance
pop wc.hInstance
mov wc.hbrBackground,COLOR_WINDOW+1
mov wc.lpszMenuName,NULL
mov wc.lpszClassName,OFFSET ClassName
invoke LoadIcon,NULL,IDI_APPLICATION
mov wc.hIcon,eax
mov wc.hIconSm,eax
invoke LoadCursor,NULL,IDC_ARROW
mov wc.hCursor,eax
invoke RegisterClassEx, addr wc
invoke CreateWindowEx,NULL, ADDR ClassName, ADDR AppName, WS_OVERLAPPEDWINDOW, CW_USEDEFAULT, CW_USEDEFAULT, CW_USEDEFAULT, CW_USEDEFAULT, NULL, NULL, hInstance, NULL
.WHILE TRUE
invoke GetMessage, ADDR msg,NULL,0,0
.BREAK .IF (!eax)
invoke TranslateMessage, ADDR msg
invoke DispatchMessage, ADDR msg
.ENDW
mov eax,msg.wParam
invoke ExitProcess, eax
WndProc proc hWnd:HWND, uMsg:UINT, wParam:WPARAM, lParam:LPARAM
.if uMsg == WM_CREATE
Invoke SetTimer,hWnd,0,5000, 0 ;Crée un timer de 5 secondes
.elseif uMsg == WM_TIMER
invoke KillTimer, hWnd, 0 ;Detruit le timer
invoke GetCursorPos, ADDR Cursor ;Récupère la position du pointeur
invoke WindowFromPoint, Cursor.x,Cursor.y ;Récupère la fenêtre sous le pointeur
mov ebx,eax
;1ere Méthode
invoke SendMessageA, ebx, 204, 0, ADDR NullString ;Supprime les *
invoke RedrawWindow, ebx, 0, 0, 1 ;Rafraichi la fenêtre
;2eme Méthode
invoke GetWindowTextA, ebx, ADDR Password, 255 ;Récupère le texte dans la fenêtre
mov [Password+eax], 0 ;Tronque le texte (GetWindowText retourne la longueur de la chaine)
invoke MessageBox, hWnd, ADDR Password, ADDR Titre, 1000h ;Affiche le texte (1000h = MB_SYSTEMMODAL)
invoke MessageBeep, -1 ;Emet un bip
invoke ExitProcess,0 ;Kill le process
.endif
invoke DefWindowProc,hWnd,uMsg,wParam,lParam
ret
WndProc endp
end start
Conclusion
Le gros avantage est que vous pouvez utiliser un programme écrit en asm sur n'importe quelle machine sans devoir installer des run-times.
J'attend vos commentaires...
Historique
- 17 juillet 2004 15:33:13 :
- 17 juillet 2004 18:40:31 :
- Suppression de l'appel à WinMain
- 18 juillet 2004 14:02:30 :
- Optimisation :
mov ebx, eax au lieu de mov handle, eax après WindowFromPoint
Sources de la même categorie
Commentaires et avis
|
Derniers Blogs
LINQ TO ENTITIESLINQ TO ENTITIES par Matthieu MEZIL
Cette semaine je suis à Montréal en tant que speaker sur Entity Framework pour l'évènement confoo . J'en profite pour remercier les organisateurs de cet évènement de m'avoir fait confiance et Access-IT de m'avoir permis d'y participer. En parallèle, j'ai ...
Cliquez pour lire la suite de l'article par Matthieu MEZIL FAIRE APPARAITRE L'ONGLET 'DéVELOPPEUR' DANS OFFICE 2010FAIRE APPARAITRE L'ONGLET 'DéVELOPPEUR' DANS OFFICE 2010 par neodante
La nouvelle interface d'Office 2010 à amener quelques modifications par rapport à celle de 2007. Certes mineures, ces modifications ont fait disparaître la case à cocher de l'onglet 'Développeur' en première page du panneau du 'bouton Office' (dans Office...
Cliquez pour lire la suite de l'article par neodante [ASTUCE] PATCH POUR MICROSOFT FORUMS NNTP BRIDGE V1[ASTUCE] PATCH POUR MICROSOFT FORUMS NNTP BRIDGE V1 par pierre
Si vous avez téléchargé comme moi Microsoft Forums NNTP Bridge V1 avant le 11 mars 2010 (voir [Astuce] Disponibilité de Microsoft Forum NNTP Bridge Version 1.0), un problème de date localisée pour les non anglais était présent. Un patch est disponibl...
Cliquez pour lire la suite de l'article par pierre PB LORS DE L'INSTALLATION SHAREPOINT 2010.PB LORS DE L'INSTALLATION SHAREPOINT 2010. par Patrick Guimonet
Lors de l'installation de SharePoint 2010, j'ai rencontré un problème de plantage à l'étape 5 du configuration Wizard. Ca se termine sur cet écran : Et en analysant le fichier de journalisation, on remarque vers la fin des 15000 et quelques lign...
Cliquez pour lire la suite de l'article par Patrick Guimonet [WF4] AJOUTER DES CONTRAINTES à UNE ACTIVITé (2/2)[WF4] AJOUTER DES CONTRAINTES à UNE ACTIVITé (2/2) par JeremyJeanson
Après mon précédent article qui attaque les contraintes par la fasse Nord de l'Everest. passons à la seconde possibilité offerte par WF4 pour valider une activité : la metadata . Je vous en ai déjà toucher un ou deux mots. La metadata dans WF4 est un élém...
Cliquez pour lire la suite de l'article par JeremyJeanson
Logiciels
Xilisoft Convertisseur Vidéo Ultimate (5.1.39.0305)XILISOFT CONVERTISSEUR VIDéO ULTIMATE (5.1.39.0305)Xilisoft Convertisseur Vidéo Ultimate est un outil puissant de conversion vidéo, facile à utilise... Cliquez pour télécharger Xilisoft Convertisseur Vidéo Ultimate Xilisoft DVD Ripper Ultimate (5.0.64.0304)XILISOFT DVD RIPPER ULTIMATE (5.0.64.0304)Xilisoft DVD Ripper Ultimate est un logiciel excellent pour copier et convertir DVD vers presque ... Cliquez pour télécharger Xilisoft DVD Ripper Ultimate Rigs of Rods (63.3)RIGS OF RODS (63.3)c'est un jeu de multi-simulation camions,autobus voitures, avions, bateaux, hélicoptère avec défo... Cliquez pour télécharger Rigs of Rods Konvertor (4.00)KONVERTOR (4.00)Le logiciel est un gestionnaire multimedia affichant, jouant et convertissant plus de 2000 format... Cliquez pour télécharger Konvertor
|