Accueil > > > ANTI-ROOTKIT
ANTI-ROOTKIT
Information sur la source
Description
Slt Donc voila un petit anti rootkit , contre les rootkit qui modifie les binaires . Le 1 er lancement créra dossier: /usr/.SauvgardeBinaire ou serons sauvgarder les binaires , ainsi que le fichier Scanner.py , qu il suffira de lancer pour scanner . Des idées pour améliorer?
Source
- #!/usr/bin/python
- # -*- coding: iso8859-1 -*-
-
- import os,md5
- from string import split
- from sys import exit
-
-
- def Scanner():
- e = """
- #!/usr/bin/python
- # -*- coding: iso8859-1 -*-
-
- import os,md5
- from string import split
- from sys import exit
-
-
- class Scanner:
- def __init__(self):
- self.corrupt = []
- self.lst = ["ls","ps","find","sudo","vim","gvim","ssh"]
- self.liste = os.listdir('/usr/bin')
- self.LenB = len(self.liste)
- try:self.BinaireSauv = open('/usr/.SauvgardeBinaire/MD5Sauv','r').read()
- except:print ("[!] Erreur : fichier invalid")
- self.BinaireSauv = split(self.BinaireSauv)
- self.LenBinSauv = self.BinaireSauv[(len(self.BinaireSauv)-1)]
-
- def LenBinaire(self):
- if (self.LenB == int(self.LenBinSauv)):
- self.Modif = 0
- else:
- self.Modif = 1
-
- def ScanBin(self):
- for buff in self.lst:
- MD5bin = "/usr/bin/%s"%(buff)
- MD5Bin = "%s"%(md5.new(MD5bin).hexdigest())
- i = 0
- while (i < len(self.BinaireSauv)):
- if (buff == self.BinaireSauv[i]):
- if (self.BinaireSauv[i+1] == MD5Bin):
- print ("[*] %s clean ."%(buff))
- else :
- print ("[!] %s modifier ."%(buff))
- self.corrupt.append(buff)
- i += 1
-
- def ResultScan(self):
- print ("Result fro the scan :")
- if (self.Modif == 1):
- print ("[!] Nombre des binaires </usr/bin> modifier")
- if (len(self.corrupt) > 0 ):
- self.corrupted = 1
- for buff in self.corrupt:
- print (" [!] %s is corrupted"%(buff))
-
- else:
- self.corrupted = 0
- print ("[*] binaire clean .")
- print ("")
-
- def Desinfect(self):
- for buff in self.corrupt:
- Binn = "/usr/.SauvgardeBinaire/%s"%(buff)
- MD5bin = "/usr/bin/%s"%(buff)
- copie = open(Binn,'rb').read()
- OpenBinary = open(MD5bin,'w')
- OpenBinary.write(copie)
- OpenBinary.close()
-
- def Root():
- uid = os.getuid()
- if (uid != 0):
- exit("[!] Erreur : Root necessaire")
-
- def main():
- print \"\"\"
- ********************************
- * Anti-Rootkit Binary modifier *
- * by *
- * Marnage *
- * Scanner *
- ********************************\"\"\"
- Root()
- print ("[-] Scan en cour ...")
- Scan = Scanner()
- Scan.LenBinaire()
- Scan.ScanBin()
- Scan.ResultScan()
- if (Scan.corrupted ):
- confirm = raw_input("Remplacer les binaires par les sauvgardes : y or n ? -> ")
- if (confirm == 'y'):
- Scan.Desinfect()
-
- if __name__ == "__main__":
- main()"""
- file = open("Scanner.py","w")
- file.write(e)
- file.close()
-
- class Sauvgarde:
- def __init__(self):
- try:
- print ("[*] Generation de la sauvgarde et des hashmd5 en cour ...")
- os.mkdir('/usr/.SauvgardeBinaire')
- self.lst = ["ls","ps","find","sudo","vim","gvim","ssh"]
- self.MD5Sauv = open('/usr/.SauvgardeBinaire/MD5Sauv','w')
- for buff in self.lst:
- MD5bin = "/usr/bin/%s"%(buff)
- self.MD5Bin = "%s %s\n"%(buff,md5.new(MD5bin).hexdigest())
- self.MD5Sauv.write(self.MD5Bin)
- os.system("touch /usr/.SauvgardeBinaire/.%s"%(buff))
- Ecr = "/usr/.SauvgardeBinaire/%s"%(buff)
- try:copie = open(MD5bin,'rb').read()
- except: print ("[!] Erreur :bianire introuvable .")
- EcrireCop = open(Ecr,'w')
- EcrireCop.write(copie)
- EcrireCop.close()
- self.liste = os.listdir('/usr/bin')
- self.LenB = len(self.liste)
- self.MD5Sauv.write(str(self.LenB))
- self.MD5Sauv.close()
- print ("[*] Generation effectuer avec succe .")
- except : print ("[!] Erreor: Generation non resussi !")
-
- def Root():
- uid = os.getuid()
- if (uid != 0):
- exit("[!] Erreur : Root necessaire")
-
- def main():
- print """
- ********************************
- * Anti-Rootkit Binary modifier *
- * by *
- * Marnage *
- * Setup *
- ********************************\n"""
- Root()
- Sauv = Sauvgarde()
- Scanner()
-
- if __name__ == "__main__":
- main()
#!/usr/bin/python
# -*- coding: iso8859-1 -*-
import os,md5
from string import split
from sys import exit
def Scanner():
e = """
#!/usr/bin/python
# -*- coding: iso8859-1 -*-
import os,md5
from string import split
from sys import exit
class Scanner:
def __init__(self):
self.corrupt = []
self.lst = ["ls","ps","find","sudo","vim","gvim","ssh"]
self.liste = os.listdir('/usr/bin')
self.LenB = len(self.liste)
try:self.BinaireSauv = open('/usr/.SauvgardeBinaire/MD5Sauv','r').read()
except:print ("[!] Erreur : fichier invalid")
self.BinaireSauv = split(self.BinaireSauv)
self.LenBinSauv = self.BinaireSauv[(len(self.BinaireSauv)-1)]
def LenBinaire(self):
if (self.LenB == int(self.LenBinSauv)):
self.Modif = 0
else:
self.Modif = 1
def ScanBin(self):
for buff in self.lst:
MD5bin = "/usr/bin/%s"%(buff)
MD5Bin = "%s"%(md5.new(MD5bin).hexdigest())
i = 0
while (i < len(self.BinaireSauv)):
if (buff == self.BinaireSauv[i]):
if (self.BinaireSauv[i+1] == MD5Bin):
print ("[*] %s clean ."%(buff))
else :
print ("[!] %s modifier ."%(buff))
self.corrupt.append(buff)
i += 1
def ResultScan(self):
print ("Result fro the scan :")
if (self.Modif == 1):
print ("[!] Nombre des binaires </usr/bin> modifier")
if (len(self.corrupt) > 0 ):
self.corrupted = 1
for buff in self.corrupt:
print (" [!] %s is corrupted"%(buff))
else:
self.corrupted = 0
print ("[*] binaire clean .")
print ("")
def Desinfect(self):
for buff in self.corrupt:
Binn = "/usr/.SauvgardeBinaire/%s"%(buff)
MD5bin = "/usr/bin/%s"%(buff)
copie = open(Binn,'rb').read()
OpenBinary = open(MD5bin,'w')
OpenBinary.write(copie)
OpenBinary.close()
def Root():
uid = os.getuid()
if (uid != 0):
exit("[!] Erreur : Root necessaire")
def main():
print \"\"\"
********************************
* Anti-Rootkit Binary modifier *
* by *
* Marnage *
* Scanner *
********************************\"\"\"
Root()
print ("[-] Scan en cour ...")
Scan = Scanner()
Scan.LenBinaire()
Scan.ScanBin()
Scan.ResultScan()
if (Scan.corrupted ):
confirm = raw_input("Remplacer les binaires par les sauvgardes : y or n ? -> ")
if (confirm == 'y'):
Scan.Desinfect()
if __name__ == "__main__":
main()"""
file = open("Scanner.py","w")
file.write(e)
file.close()
class Sauvgarde:
def __init__(self):
try:
print ("[*] Generation de la sauvgarde et des hashmd5 en cour ...")
os.mkdir('/usr/.SauvgardeBinaire')
self.lst = ["ls","ps","find","sudo","vim","gvim","ssh"]
self.MD5Sauv = open('/usr/.SauvgardeBinaire/MD5Sauv','w')
for buff in self.lst:
MD5bin = "/usr/bin/%s"%(buff)
self.MD5Bin = "%s %s\n"%(buff,md5.new(MD5bin).hexdigest())
self.MD5Sauv.write(self.MD5Bin)
os.system("touch /usr/.SauvgardeBinaire/.%s"%(buff))
Ecr = "/usr/.SauvgardeBinaire/%s"%(buff)
try:copie = open(MD5bin,'rb').read()
except: print ("[!] Erreur :bianire introuvable .")
EcrireCop = open(Ecr,'w')
EcrireCop.write(copie)
EcrireCop.close()
self.liste = os.listdir('/usr/bin')
self.LenB = len(self.liste)
self.MD5Sauv.write(str(self.LenB))
self.MD5Sauv.close()
print ("[*] Generation effectuer avec succe .")
except : print ("[!] Erreor: Generation non resussi !")
def Root():
uid = os.getuid()
if (uid != 0):
exit("[!] Erreur : Root necessaire")
def main():
print """
********************************
* Anti-Rootkit Binary modifier *
* by *
* Marnage *
* Setup *
********************************\n"""
Root()
Sauv = Sauvgarde()
Scanner()
if __name__ == "__main__":
main()
Conclusion
:)
Historique
- 01 octobre 2007 23:58:49 :
- !
Sources du même auteur
Sources de la même categorie
Commentaires et avis
|
Derniers Blogs
[MSTD10] SHAREPOINT 2010 ET TEAM FOUNDATION SERVER[MSTD10] SHAREPOINT 2010 ET TEAM FOUNDATION SERVER par phil
Un post rapide pour vous informer de la disponibilité de la vidéo de ma présentation sur SharePoint 2010 & Team Foundation Server. http://www.microsoft.com/france/vision/mstechdays10/Webcast.aspx?EID=20215d48-02e3-4d43-8c36-e53505c3b316 Dans la ...
Cliquez pour lire la suite de l'article par phil [MSTD10] SQL SERVER 2008 POUR LES DéVELOPPEURS ET VISUAL STUDIO TEAM SYSTEM DATABASE EDITION[MSTD10] SQL SERVER 2008 POUR LES DéVELOPPEURS ET VISUAL STUDIO TEAM SYSTEM DATABASE EDITION par Miiitch
Lors de cette session que j'ai animé avec Rui , j'ai eu l'occasion de présenter, en plus des nouveautés de SQL Server 2008, comment utiliser l'édition "database" de Visual Studio 2008. Le principe? Avoir les mêmes outils lors que l'on travaille avec une b...
Cliquez pour lire la suite de l'article par Miiitch [WF4] LOCALISER SIMPLEMENT UNE ACTIVITé ET SON DESIGNER WPF[WF4] LOCALISER SIMPLEMENT UNE ACTIVITé ET SON DESIGNER WPF par JeremyJeanson
La localisation . vous connaissez ce system miraculeux qui permet à votre application de s'afficher dans la langue de l'utilisateur (à condition de l'avoir intégrée dans votre programme). Comment mettre en place la localisation dans WF4? Cette question m'...
Cliquez pour lire la suite de l'article par JeremyJeanson [TECHDAYS 2010] WEBCASTS ET SLIDES[TECHDAYS 2010] WEBCASTS ET SLIDES par Audrey
Les webcasts des sessions des Techdays 2010 sont maintenant disponibles en ligne ! Me concernant, voici les slides et le webcast de la session Blend 3 / Skechtflow : Dessinez c'est gagné ! (animée avec Michel Perfetti ) Les slides et le webcast : Blend 3/...
Cliquez pour lire la suite de l'article par Audrey NDEPEND V3. J'ADORE SON INTéGRATION AVEC VS2010NDEPEND V3. J'ADORE SON INTéGRATION AVEC VS2010 par tja
Après une petite introduction à son utilisation que vous pouvez lire ici j'ai également eu envie d'installer ma copie et de jouer un peu avec. Après les premières minutes de son utilisation. J'ai tout de suite ADORE. L'utilisation intuitive sans besoi...
Cliquez pour lire la suite de l'article par tja
Forum
MCD LYCéMCD LYCé par Wiliam123
Cliquez pour lire la suite par Wiliam123
Logiciels
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 Xlite (v 3.0 build 41150)XLITE (V 3.0 BUILD 41150)c'est un logiciel qui permet de téléphoner par Internet à l'aide d'un compte SIP pratique pour le... Cliquez pour télécharger Xlite Academy System (10.9.3.0)ACADEMY SYSTEM (10.9.3.0)Logiciel de gestion des établissements.
- élèves/étudiants (inscription, dossier, absence...)
-... Cliquez pour télécharger Academy System
|