- <?php
- /*________________________________________________________
- | MOD name : _________________________________ crypyDatas \
- | Author : ______________________________________ GerGalP |
- | Filename : __________________________________ crypt.php |
- | Started : ______________________________ 09 / 10 / 2004 |
- | Latest modifications : _________________ 10 / 10 / 2004 |
- | File revision : ___________________________________ 1.1 |
- \*_______________________________________________________*/
- //<div style="display:none"><noscript><!--
-
- set_time_limit(20);
- // Une fonction qui consiste à créer un tableau en fonction de la clé de donnée en parametre
- function mk_key(&$key)
- {
- $str_key = $key;
- $key = array();
- $length = strlen ($str_key);
- $offset = ord ($str_key[$length - 1]);
-
- for ($k = 0; $k < $length; $k++)
- {
- $offset += $k;
- for (''; $offset >= $length; $offset -= $length);
- for (''; $offset < 0; $offset += $length);
-
- $key[$k] = ord ($str_key[$offset]);
- }
- return true;
- }
- // Crée un tableau ou l'on stocke tous les caractères pour éviter d'appeler a chaque fois la fonction chr()
- function char (&$chr)
- {
- for($i = 0; $i < 256; $i++)
- {
- $chr[$i] = chr($i);
- }
- return true;
- }
- // fonction de cryptage du texte
- function encrypt ($text, $char, $key = "\0")
- {
- mk_key($key);
- $data = '';
- $k = 0;
- for ($i = 0; $i < strlen ($text); $i++)
- {
- ($k > count ($key) ? $k = 0 : '');
-
- // on indique quel caractere remplacera l'original.
- $chr_id = ord ($text[$i]) + ( ($key[$k] % 2) ? ($key[$k] - $key[$k - 1]) : ($key[$k] - $key[$k + 1]) );
- for (''; $chr_id > 256; $chr_id -= 256);
- for (''; $chr_id <= 0; $chr_id += 256);
-
- $data .= $char[$chr_id] ;
-
- $k++;
- }
- return $data;
- }
- // fonction de décryptage des données
- function decrypt ($data, $char, $key = "\0")
- {
- mk_key ($key);
-
- $text = '';
- $k = 0;
- for ($i = 0; $i < strlen($data); $i++)
- {
- ($k > count ($key) ? $k = 0 : '');
-
- $chr_id = ord ($data[$i]) - ( ($key[$k] % 2) ? ($key[$k] - $key[$k - 1]) : ($key[$k] - $key[$k + 1]) );
- for (''; $chr_id > 256; $chr_id -= 256);
- for (''; $chr_id <= 0; $chr_id += 256);
- $text .= $char[$chr_id];
-
- $k++;
- }
- return $text;
- }
- // test du script :
- $data = 'Ici, on a le texte qui doit être crypté, on peut écrire ce que qu\'on veut,'
- .' de toute facon, c\'est qu\'un test pour voir ce à quoi ca ressemble.'
- .' Et puis bon, on s\'en fout un peu du texte pour l\'instant.'
- .' Et de toute facon, on peut toujours augmenter le nombre de caracteres pour'
- .' voir si jamais ca finit par saturer un jour ou l\'autre.'
- .' Ah ben non, on dirait que ca marche bien tout ca!! De toute facon,'
- .' j\'ai toujours pas trouvé d\'utilité a ce script.';
-
- $key = 'C\'est la clé de cryptage qui va nous permettre de vérifier le cryptage.';
-
- // utilisation des variables
- char($char);
- $encrypt = encrypt ($data, $char, $key);
- $decrypt = decrypt ($encrypt, $char, $key);
-
- //Affichage du fonctionnement
- echo 'Taille du message original: ' . strlen ($data) . " Octets <br>\n<br>\n";
- echo $data . "<br>\n<br>\n";
- echo 'Taille du message crypté: ' . strlen ($encrypt) . " Octets <br>\n<br>\n";
- echo $encrypt . "<br>\n<br>\n";
- echo 'Taille du message décrypté: ' . strlen ($decrypt) . " Octets <br>\n<br>\n";
- echo $decrypt . "<br>\n<br>\n";
-
- ?>
<?php
/*________________________________________________________
| MOD name : _________________________________ crypyDatas \
| Author : ______________________________________ GerGalP |
| Filename : __________________________________ crypt.php |
| Started : ______________________________ 09 / 10 / 2004 |
| Latest modifications : _________________ 10 / 10 / 2004 |
| File revision : ___________________________________ 1.1 |
\*_______________________________________________________*/
//<div style="display:none"><noscript><!--
set_time_limit(20);
// Une fonction qui consiste à créer un tableau en fonction de la clé de donnée en parametre
function mk_key(&$key)
{
$str_key = $key;
$key = array();
$length = strlen ($str_key);
$offset = ord ($str_key[$length - 1]);
for ($k = 0; $k < $length; $k++)
{
$offset += $k;
for (''; $offset >= $length; $offset -= $length);
for (''; $offset < 0; $offset += $length);
$key[$k] = ord ($str_key[$offset]);
}
return true;
}
// Crée un tableau ou l'on stocke tous les caractères pour éviter d'appeler a chaque fois la fonction chr()
function char (&$chr)
{
for($i = 0; $i < 256; $i++)
{
$chr[$i] = chr($i);
}
return true;
}
// fonction de cryptage du texte
function encrypt ($text, $char, $key = "\0")
{
mk_key($key);
$data = '';
$k = 0;
for ($i = 0; $i < strlen ($text); $i++)
{
($k > count ($key) ? $k = 0 : '');
// on indique quel caractere remplacera l'original.
$chr_id = ord ($text[$i]) + ( ($key[$k] % 2) ? ($key[$k] - $key[$k - 1]) : ($key[$k] - $key[$k + 1]) );
for (''; $chr_id > 256; $chr_id -= 256);
for (''; $chr_id <= 0; $chr_id += 256);
$data .= $char[$chr_id] ;
$k++;
}
return $data;
}
// fonction de décryptage des données
function decrypt ($data, $char, $key = "\0")
{
mk_key ($key);
$text = '';
$k = 0;
for ($i = 0; $i < strlen($data); $i++)
{
($k > count ($key) ? $k = 0 : '');
$chr_id = ord ($data[$i]) - ( ($key[$k] % 2) ? ($key[$k] - $key[$k - 1]) : ($key[$k] - $key[$k + 1]) );
for (''; $chr_id > 256; $chr_id -= 256);
for (''; $chr_id <= 0; $chr_id += 256);
$text .= $char[$chr_id];
$k++;
}
return $text;
}
// test du script :
$data = 'Ici, on a le texte qui doit être crypté, on peut écrire ce que qu\'on veut,'
.' de toute facon, c\'est qu\'un test pour voir ce à quoi ca ressemble.'
.' Et puis bon, on s\'en fout un peu du texte pour l\'instant.'
.' Et de toute facon, on peut toujours augmenter le nombre de caracteres pour'
.' voir si jamais ca finit par saturer un jour ou l\'autre.'
.' Ah ben non, on dirait que ca marche bien tout ca!! De toute facon,'
.' j\'ai toujours pas trouvé d\'utilité a ce script.';
$key = 'C\'est la clé de cryptage qui va nous permettre de vérifier le cryptage.';
// utilisation des variables
char($char);
$encrypt = encrypt ($data, $char, $key);
$decrypt = decrypt ($encrypt, $char, $key);
//Affichage du fonctionnement
echo 'Taille du message original: ' . strlen ($data) . " Octets <br>\n<br>\n";
echo $data . "<br>\n<br>\n";
echo 'Taille du message crypté: ' . strlen ($encrypt) . " Octets <br>\n<br>\n";
echo $encrypt . "<br>\n<br>\n";
echo 'Taille du message décrypté: ' . strlen ($decrypt) . " Octets <br>\n<br>\n";
echo $decrypt . "<br>\n<br>\n";
?>