Cryptoplus!

5/5 (11 avis)

Snippet vu 6 974 fois - Téléchargée 36 fois

Contenu du snippet

Voici (encore un!) un crypteur/décrypteur de texte avec une clé de cryptage. Je ne pense pas qu'une source avec cette methode de cryptage ai déja été postée....
Mais venons en aux fait ;) :
Ce code permet de crypter un texte avec une clé numérque qui servira de clé de cryptatge, pour décrypter ce même texte crypté, il faudra utiliser cette même clé de cryptage.... Voilà !!

Source / Exemple :


<?php
// Auteur : Roberto
// 		roberto@netcourrier.com
// Cette fonction permet de crypter une chaine de caractère avec une clé de chiffrement.
// utilisation : 
// 1) Pour crypter 	 : cryptage("Roberto","123456",crypt"); ==> renvoie "sqeiwzp";
// 2) Pour décrypter : cryptage("sqeiwzp","123456","decrypt"); ==> renvoie "roberto";
// Les valeurs qui se trouvent dans le tableau '$char' peuvent être dans n'importe quel ordre,
// si vous voulez que le script supporte des caractère tesls que les accents, etc, il suffit de les rajouter n'importe ou
// dans le tableau '$char' sans avoir à modifier quoi que ce soit.
// Si vous avez des questions, commentaires, ou remarques, n"hésitez pas à m'en informer soit via e-mail ou bien via un commentaire sur la soutce (www.phpcs.com)

function cryptage($text,$ckey,$mode)
{
	// tableau contenant l'alphabet alphabétique et numérique
	$char = array("0","1","2","3","4","5","6","7","8","9","a","b","c","d","e","f","g","h","i","j","k","l","m","n","o","p","q","r","s","t","u","v","w","x","y","z");
	// compte le nombre de charactère contenu dans le tableau alpha-numérique
	$nbch = count($char);
	// on compte la longueur de la chaine de caractère à crypter
	$nbtx = strlen($text);
	// on compte la longueur de la clé de cryptage
	$nint = strlen($ckey);
	// on initialise la variable qui va contenir le résultat
	$outtx = "";
	// On initialise le tableau qui va comptenir les caractère de la chaine de caractère à crypter
	$ar_tx = array();
	// On initialise le tableau qui va contenir la clé de cryptage. Not : ce tableau aura le meme nombre d'élements que le tableau '$ar_tx'
	$ar_ck = array();
	// on lance une boucle qui va faire n fois un rajout de caractère dans '$ar_tx' ainsi que dans '$ar_ck' (n est la longueur de la chaine de caractère à crypter)
	for($a=0;$a<$nbtx;$a++)
	{
		// on ajoute  la n eme lettre de $text dans '$ar_tx'
		array_push($ar_tx,$text[$a]);
		
		// on ajoute le n % nint eme nombre de $ckey dans '$ar_ck'
		$pointer = $a % $nint;
		array_push($ar_ck,$ckey[$pointer]);
		// Note : 
		// les tableaux '$ar_tx' et '$ar_ck' sont lié de la façon suivante :
		// par exemple, le texte à crypter est roberto; la clé de cryptage est 123;
		// $ar_tx sera : 'array("r","o","b","e","r","t","o")';
		// $ar_ck sera : 'array("1","2","3","1","2","3","1")';
		// ce qui signifie que le r(1) sera décalé de 1 place dans le tableau '$char',
		//                     le o(2) sera décalé de 2 places dans le tableau '$char',
		//                     le b(3) sera décalé de 3 places dans le tableau '$char',
		//                     le e(4) sera décalé de 1 place dans le tableau '$char',
		//                     et ainsi de suite ....
	}

	// on lance une boucle qui va faire n fois (n étant toujours le meme dans tout le script) un parcour + un décalage dans '$char' pour ensuite le rajouter dans '$outtx'
	for($b=0;$b<$nbtx;$b++)
	{
		// si l'on veut crypter
		if($mode == "crypt")
		{
			// recherche la clé de la n eme valeur de '$ra_tx' dans '$char'
			$pointer = array_search($ar_tx[$b],$char);
			// ajoute la valeur de la clé + déplacement dans '$char' dans '$outtx'
			$outtx = $outtx.$char[($pointer + $ar_ck[$b]) % $nbch];
		}
		// sinon si on veut décrypter
		elseif($mode == "decrypt")
		{
			// recherche la clé de la n eme valeur de '$ra_tx' dans '$char'
			$pointer = array_search($ar_tx[$b],$char);
			// ajoute la valeur de la clé - déplacement dans '$char' dans '$outtx'
			$outtx = $outtx.$char[($pointer - $ar_ck[$b]) % $nbch];
		}
	}
	// on retourne $outtx....
	return $outtx;
	
	// et voilà !
}

?>

Conclusion :


Voilà !
Des questions, remarques commentaires ?
N'hésitez pas soit via email (roberto@netcourrier.com) soit en rajoutant un commentaire....

@+, Rob.

PS: j'ai mis cette source en niveau 2... car je pense pas qu'elle soit trop simple ou trop compliquée...
Ajouter un commentaire Commentaires
coucou747 Messages postés 12303 Date d'inscription mardi 10 février 2004 Statut Membre Dernière intervention 30 juillet 2012 44
9 août 2004 à 14:13
oh mais c'est du cryptage vraiment basique ça... dsl de te dire ça mais si tu veux pouvoir essayer de passer les crackeurs alors essai plutot rsa ou aes
cs_rob85 Messages postés 16 Date d'inscription samedi 7 février 2004 Statut Membre Dernière intervention 29 octobre 2006
9 août 2004 à 15:06
Ben j'y travaille !!! Et sinon est-ce que tu connais un site ou on peut apprendre tout ca ???
cs_rob85 Messages postés 16 Date d'inscription samedi 7 février 2004 Statut Membre Dernière intervention 29 octobre 2006
9 août 2004 à 15:07
Ben j'y travaille !!! Et sinon est-ce que tu connais un site ou on peut apprendre tout ca ???
coucou747 Messages postés 12303 Date d'inscription mardi 10 février 2004 Statut Membre Dernière intervention 30 juillet 2012 44
9 août 2004 à 15:09
bah en fait, j'avais trouvé ça mais comme un con j'ai téléchargé toute la doc snas même penser a relever l'adresse...

donne moi ton mail, je t'envois de la doc (je dois avoir une centaine de page en format ps et pdf...)
drill_95 Messages postés 1 Date d'inscription mercredi 11 août 2004 Statut Membre Dernière intervention 11 août 2004
11 août 2004 à 21:55
Pourrais tu m'envoyer aussi la doc svp
drill@ifrance.com
merci bcp

Vous n'êtes pas encore membre ?

inscrivez-vous, c'est gratuit et ça prend moins d'une minute !

Les membres obtiennent plus de réponses que les utilisateurs anonymes.

Le fait d'être membre vous permet d'avoir un suivi détaillé de vos demandes et codes sources.

Le fait d'être membre vous permet d'avoir des options supplémentaires.