Cryptoplus!

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...

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.