Accueil > > > CAPTCHA ( ANTI-SPAM ) ACCESSIBLE À TOUS !
CAPTCHA ( ANTI-SPAM ) ACCESSIBLE À TOUS !
Information sur la source
Description
Voici une class anti-spam de mon crû. Je me suis basé sur le travail d’un collègue (bien plus ingénieux que moi…) qui souhaitait faire un captcha qui soit accessible à tous. Par « accessible à tous » on entend (ce fameux collègue et moi) accessible aux personnes visuellement déficientes. Il est vrais qu’un système proposant une image avec des lettre déformé est se qui se fait de mieux. Cependant les personnes soufrant de déficience visuelle ne peuvent le lire, donc de jouir du même droit que les personnes bien portante et donc il se retrouve dans l’impossibilité de pouvoir accéder à ce contenu où service protégé ! Dans le zip vous trouverez tout ce qui faut! pour en savoir plus : http://www.mon-beulogue.com/php/14-captcha-accessi ble-a-tous.html
Source
- //un ficheir de langue qui doit être composé de la manière suivante :
- $_LANG[1] = 'première';
- $_LANG[2] = 'seconde';
- $_LANG[3] = 'troisième';
- $_LANG[4] = 'quatrième';
- $_LANG[5] = 'cinquième';
- $_LANG[6] = 'sixième';
- $_LANG[7] = 'septième';
- $_LANG[8] = 'huitième';
- $_LANG[9] = 'neuvième';
- $_LANG['noSpam'] = array('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','A','B','C','D','E','F',
- 'G','H','Y','J','K','L','M','N','O','P','Q','R','S','U','V','W','X','Y','Z');
-
- //La classe en elle même
- <?php
- /*************************************************************************************
- * Développé par Valerian Girard
- * sur une idée original de Pilgrim (My Master)
- * 5/10/2006
- *************************************************************************************/
-
- class captcha {
- var $lang;
-
- function __construct($_lang){
- $this->lang = $_lang;
- }
-
- /*************************************************************************************
- * Retourne la position de la lettre à saisir ainsi q'une chaine de letter
- * et la cahine de test à placer dans un input hidden
- *
- * position : c'est le text de position de la lettre à saisir
- * captcha : C'est la cahine de lettre dans laquelle le visiteur daoit choisir
- * Elle est encodé en ISO affin de réduire les risques de spam
- * theTrue : Cette chaine va servir pour tester si le visiteur à bien saisie la bonne
- * lettre
- *************************************************************************************/
- function noSpam(){
- $tmp = "";
- for($x=0; $x<=13; $x++){
- $tmp .= " ".$this->lang['noSpam'][rand(0, count($this->lang)-1)];
- }
- $tmp = $this->iso_encode($tmp);
- $pos = rand(1,9);
- $text = $this->iso_encode($this->lang[$pos]);
- $true = $tmp.'-'.MD5($pos);
- return array('position' => $text, 'captcha' => $tmp, 'theTrue' => $true );
- }
-
- /*************************************************************************************
- * Retourne Vrais si la lettre a été saisie correctement
- * et faux dans le cas contraire
- *************************************************************************************/
-
- function testNoSpam($char, $theTrue){
- $char = (get_magic_quotes_gpc)?$char:addslashes($char);
- $theTrue = (get_magic_quotes_gpc)?$theTrue:addslashes($theTrue);
-
- $myMD5 = array( 'c4ca4238a0b923820dcc509a6f75849b' => 1,
- 'c81e728d9d4c2f636f067f89cc14862c' => 2,
- 'eccbc87e4b5ce2fe28308fd9f2a7baf3' => 3,
- 'a87ff679a2f3e71d9181a67b7542122c' => 4,
- 'e4da3b7fbbce2345d7772b0674a318d5' => 5,
- '1679091c5a880faf6fb5e6087eb1b2dc' => 6,
- '8f14e45fceea167a5a36dedd4bea2543' => 7,
- 'c9f0f895fb98ab9159f51fd0297e236d' => 8,
- '45c48cce2e2d7fbdea1afc51c7c6ad26' => 9);
-
- $tmpLettre = explode(" ", $theTrue);
-
- $numLettre = substr($theTrue,strpos($theTrue, '-')+1, strlen($theTrue));
-
- //test si le captchat est invalide
- if( $char != $tmpLettre[$myMD5[$numLettre]]){
- return false;
- exit;
- }else{
- //si on arrive ici c'est que la captcha est valide
- return true;
- exit;
- }
-
- }
-
- function iso_encode($str){
- $carac = array('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','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','–');
-
- $caracIso = array('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','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','–');
-
- $str = str_replace($carac, $caracIso, $str);
- return utf8_encode($str);
- }
-
- function iso_decode($str){
- $carac = array('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','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','–');
-
- $caracIso = array('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','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','–');
- $str = str_replace($caracIso, $carac, $str);
- return utf8_encode($str);
- }
-
- function html_encode($str){
- $caracHtml = array('"','&','€','‹','›','œ','ÿ','¡','¢','£','¤','¥','¦','§',
- '¨','©','ª','«','¬','','®','¯','°','±','²','³','´','µ','¶','·','¸','¹','º','»','¼',
- '½','¾','¿','à','á','â','ã','ä','å','æ','ç','è','é','ê','ë','ì','í','î','ï','ð','ñ',
- 'ò','ó','ô','õ','ö','×','ø','ù','ú','û','ü','ý','þ','ß','à','á','â','ã','ä','å','æ',
- 'ç','è','é','ê','ë','ì','í','î','ï','ð','ñ','ò','ó','ô','õ','ö','÷','ø','ù','ú','û',
- 'ü','ý','þ','ÿ','"','&','‹','›');
-
- $html = array('"','&','?','<','>','?','ÿ','¡','¢','£','¤','¥','¦','§','¨','©',
- 'ª','«','¬','','®','&masr;','°','±','²','³','´','µ','¶','·','¸','¹','º','»','¼','½',
- '¾','¿','à','á','â','ã','ä','å','æ','ç','è','é','ê','ë','ì','í','î','ï','ð','ñ','ò',
- 'ó','ô','õ','ö','×','ø','ù','ú','û','ü','ý','þ','ß','à','á','â','ã','ä','å','æ','ç',
- 'è','é','ê','ë','ì','í','î','ï','ð','ñ','ò','ó','ô','õ','ö','÷','ø','ù','ú','û','ü',
- 'ý','þ','ÿ','"','&','<','>');
-
- $str = str_replace($caracHtml, $html, $str);
- return utf8_encode($str);
- }
- }
- // fin de la class
-
- //contenu du fichier de langue nomé ici lang_fr.php
- <?php
- //système anti-spam
- $_LANG['soucie de securite'] = 'Sécurité anti-spam: merci de nous indiquer la ';
- $_LANG['lettre du mot en gras ci-dessous:'] = ' lettre du mot en gras ci-dessous:';
- $_LANG['Erreur Code anti-spam'] = 'Vous avez saisie la mauvaise lettre';
- $_LANG[1] = 'première';
- $_LANG[2] = 'seconde';
- $_LANG[3] = 'troisième';
- $_LANG[4] = 'quatrième';
- $_LANG[5] = 'cinquième';
- $_LANG[6] = 'sixième';
- $_LANG[7] = 'septième';
- $_LANG[8] = 'huitième';
- $_LANG[9] = 'neuvième';
-
- $_LANG['noSpam'] = array('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','A','B','C','D','E','F','G','H','Y','J',
- 'K','L','M','N','O','P','Q','R','S','U','V','W','X','Y','Z');
- ?>
- // fin du fichier de langue
-
-
-
-
- // contenu du fichier monFichier.php
- <?php
- //inclusion de la class anti-spam
- include('captcha.class.php');
-
- //inclusion du fichier de lang
- include('lang_fr.php');
-
- //création d'une instance de la class de captcha
- $captcha = new captcha($_LANG);
- //appelle de la fonction anti-spam et stokage des valeurs
- $tmp = $captcha->noSpam();
-
- // si le formulaire est retouré on va tester si la lettre saisie est bien la bonne
- if(isset($_POST['char'])){
- //on affiche le résultat
- var_dump($captcha->testNoSpam($_POST['char'], $_POST['TellMeTheTrue']));
- }
-
- ?>
-
- <form action="monFichier.php" method="post">
- Saisir la <?php echo $tmp['position'] ?> lettre du text ci-dessous <br/>
- <?php echo $tmp['captcha'] ?>
- <input type="hidden" name="TellMeTheTrue" value="<?php echo $tmp['theTrue']; ?>" />
- <input type="text" name="char"/>
- <input type="submit" value="goOn" />
- </form>
//un ficheir de langue qui doit être composé de la manière suivante :
$_LANG[1] = 'première';
$_LANG[2] = 'seconde';
$_LANG[3] = 'troisième';
$_LANG[4] = 'quatrième';
$_LANG[5] = 'cinquième';
$_LANG[6] = 'sixième';
$_LANG[7] = 'septième';
$_LANG[8] = 'huitième';
$_LANG[9] = 'neuvième';
$_LANG['noSpam'] = array('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','A','B','C','D','E','F',
'G','H','Y','J','K','L','M','N','O','P','Q','R','S','U','V','W','X','Y','Z');
//La classe en elle même
<?php
/*************************************************************************************
* Développé par Valerian Girard
* sur une idée original de Pilgrim (My Master)
* 5/10/2006
*************************************************************************************/
class captcha {
var $lang;
function __construct($_lang){
$this->lang = $_lang;
}
/*************************************************************************************
* Retourne la position de la lettre à saisir ainsi q'une chaine de letter
* et la cahine de test à placer dans un input hidden
*
* position : c'est le text de position de la lettre à saisir
* captcha : C'est la cahine de lettre dans laquelle le visiteur daoit choisir
* Elle est encodé en ISO affin de réduire les risques de spam
* theTrue : Cette chaine va servir pour tester si le visiteur à bien saisie la bonne
* lettre
*************************************************************************************/
function noSpam(){
$tmp = "";
for($x=0; $x<=13; $x++){
$tmp .= " ".$this->lang['noSpam'][rand(0, count($this->lang)-1)];
}
$tmp = $this->iso_encode($tmp);
$pos = rand(1,9);
$text = $this->iso_encode($this->lang[$pos]);
$true = $tmp.'-'.MD5($pos);
return array('position' => $text, 'captcha' => $tmp, 'theTrue' => $true );
}
/*************************************************************************************
* Retourne Vrais si la lettre a été saisie correctement
* et faux dans le cas contraire
*************************************************************************************/
function testNoSpam($char, $theTrue){
$char = (get_magic_quotes_gpc)?$char:addslashes($char);
$theTrue = (get_magic_quotes_gpc)?$theTrue:addslashes($theTrue);
$myMD5 = array( 'c4ca4238a0b923820dcc509a6f75849b' => 1,
'c81e728d9d4c2f636f067f89cc14862c' => 2,
'eccbc87e4b5ce2fe28308fd9f2a7baf3' => 3,
'a87ff679a2f3e71d9181a67b7542122c' => 4,
'e4da3b7fbbce2345d7772b0674a318d5' => 5,
'1679091c5a880faf6fb5e6087eb1b2dc' => 6,
'8f14e45fceea167a5a36dedd4bea2543' => 7,
'c9f0f895fb98ab9159f51fd0297e236d' => 8,
'45c48cce2e2d7fbdea1afc51c7c6ad26' => 9);
$tmpLettre = explode(" ", $theTrue);
$numLettre = substr($theTrue,strpos($theTrue, '-')+1, strlen($theTrue));
//test si le captchat est invalide
if( $char != $tmpLettre[$myMD5[$numLettre]]){
return false;
exit;
}else{
//si on arrive ici c'est que la captcha est valide
return true;
exit;
}
}
function iso_encode($str){
$carac = array('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','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','–');
$caracIso = array('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','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','–');
$str = str_replace($carac, $caracIso, $str);
return utf8_encode($str);
}
function iso_decode($str){
$carac = array('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','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','–');
$caracIso = array('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','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','–');
$str = str_replace($caracIso, $carac, $str);
return utf8_encode($str);
}
function html_encode($str){
$caracHtml = array('"','&','€','‹','›','œ','ÿ','¡','¢','£','¤','¥','¦','§',
'¨','©','ª','«','¬','','®','¯','°','±','²','³','´','µ','¶','·','¸','¹','º','»','¼',
'½','¾','¿','à','á','â','ã','ä','å','æ','ç','è','é','ê','ë','ì','í','î','ï','ð','ñ',
'ò','ó','ô','õ','ö','×','ø','ù','ú','û','ü','ý','þ','ß','à','á','â','ã','ä','å','æ',
'ç','è','é','ê','ë','ì','í','î','ï','ð','ñ','ò','ó','ô','õ','ö','÷','ø','ù','ú','û',
'ü','ý','þ','ÿ','"','&','‹','›');
$html = array('"','&','?','<','>','?','ÿ','¡','¢','£','¤','¥','¦','§','¨','©',
'ª','«','¬','','®','&masr;','°','±','²','³','´','µ','¶','·','¸','¹','º','»','¼','½',
'¾','¿','à','á','â','ã','ä','å','æ','ç','è','é','ê','ë','ì','í','î','ï','ð','ñ','ò',
'ó','ô','õ','ö','×','ø','ù','ú','û','ü','ý','þ','ß','à','á','â','ã','ä','å','æ','ç',
'è','é','ê','ë','ì','í','î','ï','ð','ñ','ò','ó','ô','õ','ö','÷','ø','ù','ú','û','ü',
'ý','þ','ÿ','"','&','<','>');
$str = str_replace($caracHtml, $html, $str);
return utf8_encode($str);
}
}
// fin de la class
//contenu du fichier de langue nomé ici lang_fr.php
<?php
//système anti-spam
$_LANG['soucie de securite'] = 'Sécurité anti-spam: merci de nous indiquer la ';
$_LANG['lettre du mot en gras ci-dessous:'] = ' lettre du mot en gras ci-dessous:';
$_LANG['Erreur Code anti-spam'] = 'Vous avez saisie la mauvaise lettre';
$_LANG[1] = 'première';
$_LANG[2] = 'seconde';
$_LANG[3] = 'troisième';
$_LANG[4] = 'quatrième';
$_LANG[5] = 'cinquième';
$_LANG[6] = 'sixième';
$_LANG[7] = 'septième';
$_LANG[8] = 'huitième';
$_LANG[9] = 'neuvième';
$_LANG['noSpam'] = array('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','A','B','C','D','E','F','G','H','Y','J',
'K','L','M','N','O','P','Q','R','S','U','V','W','X','Y','Z');
?>
// fin du fichier de langue
// contenu du fichier monFichier.php
<?php
//inclusion de la class anti-spam
include('captcha.class.php');
//inclusion du fichier de lang
include('lang_fr.php');
//création d'une instance de la class de captcha
$captcha = new captcha($_LANG);
//appelle de la fonction anti-spam et stokage des valeurs
$tmp = $captcha->noSpam();
// si le formulaire est retouré on va tester si la lettre saisie est bien la bonne
if(isset($_POST['char'])){
//on affiche le résultat
var_dump($captcha->testNoSpam($_POST['char'], $_POST['TellMeTheTrue']));
}
?>
<form action="monFichier.php" method="post">
Saisir la <?php echo $tmp['position'] ?> lettre du text ci-dessous <br/>
<?php echo $tmp['captcha'] ?>
<input type="hidden" name="TellMeTheTrue" value="<?php echo $tmp['theTrue']; ?>" />
<input type="text" name="char"/>
<input type="submit" value="goOn" />
</form>
Historique
- 10 octobre 2006 12:36:47 :
- Formatage du text pour éviter l'étirement de la page (désolé)
Rajout du code du fichier "monFichier.php"
Rajout du code du fichier de langue
- 10 octobre 2006 12:37:34 :
- Formatage du text pour éviter l'étirement de la page (désolé)
Rajout du code du fichier "monFichier.php"
Rajout du code du fichier de langue
- 10 octobre 2006 12:41:19 :
- Formatage du text pour éviter l'étirement de la page (désolé)
Rajout du code du fichier "monFichier.php"
Rajout du code du fichier de langue
- 03 novembre 2006 12:06:14 :
- mise a jour des sources
Sources de la même categorie
Commentaires et avis
Discussions en rapport avec ce code source dans le forum
scrollbar et accessibilité [ par labinocle ]
bonjour, est-ce que qqu'un sait si il y a une autre façon de faire les scrollbar qu'en passant par la modification de la feuille de style sur body ? c
AntiSpam [ par Maxxou59 ]
Bonjour a tous j'aimerais lancer un grand projet pour lutter contre le spam.Dans ce sens j'aurais besoin d'aide pour créer des applications web, les a
probleme affichage captcha [ par Jarod1980 ]
Jarod_Delaware
CAPTCHA [ par hlbmatos ]
J'ai installé cryptographp dans mon livre d'or mais quoi que je fasse, quand j'envoie un message vers mon livre d'or, il n'est pas vérifié par le cryp
Pb pour rafraichir un captcha [ par sebastien_et_typh ]
Bonsoir,je rencontre 2 problèmes : - Le premier : j'ai installer un captcha sur mon site lors de l'inscription (j'avais pris le code de ce captcha ici
comment afficher un captcha à la fin d'un formulaire ? [ par tiger159 ]
Bonjour,j'aimerais savoir comment intégrer un captchaà la suite de l'affichage d'un formulaire.(Il semble que ce soit dû à 'header' qui a déjàenvoyé s
Formulaire de contact compatibilité avec free.fr [ par adamtheboss ]
Bonjour,J'ai créé un site chez free.fr où j'ai integré un script contact captcha, j'ai aussi créé un dossier sessions vide à la racine du site. Le for
php et antispam ? [ par leroger ]
[^^clinoeil1]Bonjour, Bon, maintenant mon formulaire de recommandation fonctionne nickel et je crée un nouveau post car cela concerne éventuellement
Buzii Captcha et fiabilité ! [ par kikifrance ]
Salut chez vous ! J'aimerais votre avis sur la fiabilité d'un Captcha tel que celui-ci: [url=http://www.buzii.com/buzii_captcha.php]http://www.buzii
[BAR]Crack Captcha [ par kohntark ]
Salut, Je me permet de poster ici car, même si il concerne avant tout le développement Web, le sujet fait en priorité appel à d'autres langages "plus
|
Derniers Blogs
SESSION SILVERLIGHT 5 3D : SLIDES ET DEMOSSESSION SILVERLIGHT 5 3D : SLIDES ET DEMOS par Groc
Durant les techdays, j'ai eu le plaisir d'animer une session sur Silverlight 5 et la 3D avec Simon Ferquel. Comme promis, voici nos slides et mes démos (celles avec le viper BSG) ici et là. Pour mémoire, les démos utilisent toutes le viper BSG...
Cliquez pour lire la suite de l'article par Groc [TECHDAYS 2012] SESSION WEBMATRIX 2 : LE COUTEAU SUISSE GRATUIT POUR VOS DéVELOPPEMENTS WEB - SLIDES[TECHDAYS 2012] SESSION WEBMATRIX 2 : LE COUTEAU SUISSE GRATUIT POUR VOS DéVELOPPEMENTS WEB - SLIDES par gpommier
Suite à la session que j'ai présenté sur WebMatrix 2, vous pouvez trouver les slides ici, ainsi que les démos en packages nuget : démos1 et démos2 J'en profite pour remercier chaleureusement tous ceux qui sont venus très nombreux à cette sess...
Cliquez pour lire la suite de l'article par gpommier [SHAREPOINT] LES SESSIONS TECHDAYS 2012.[SHAREPOINT] LES SESSIONS TECHDAYS 2012. par Patrick Guimonet
Voici donc pour ceux qui n'ont pas pu venir, ou ceux qui n'ont pas pu toutes les suivre la liste des sessions SharePoint aux TechDays 2012, que je mettrais à jour dès que les liens des vidéo seront disponibles. Ou ici : http...
Cliquez pour lire la suite de l'article par Patrick Guimonet TECHDAYS PARIS 2012 : SESSION PLEINIèRE JOUR 3TECHDAYS PARIS 2012 : SESSION PLEINIèRE JOUR 3 par ROMELARD Fabrice
Speaker: Bernard Ourghanlian Cette session est comme chaque jour transmise en live par BrainSonic, et j'ai donc suivi cette troisième pleinière par ce moyen sur mon iPad . Elle est dédiée comme chaque année à la mise en perspective de l'é...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice MISHRA READER : UN LECTEUR RSS TRèS ZUNE STYLE EN OPEN SOURCE !MISHRA READER : UN LECTEUR RSS TRèS ZUNE STYLE EN OPEN SOURCE ! par Vko
Hier durant une session dédiée aux Techdays 2012, j'ai eu le plaisir d'annoncer la sortie de la Béta 2 de Mishra Reader. C'est quoi ? Pour les utilisateurs, c'est une vraie expérience de lecture de flux RSS sur Windows. Rien à voir avec les produit...
Cliquez pour lire la suite de l'article par Vko
Logiciels
Academy System (17.2.1.0)ACADEMY SYSTEM (17.2.1.0)Logiciel de gestion des établissements.
- élèves/étudiants (inscription, dossier, absence...)
-... Cliquez pour télécharger Academy System Easy-Planning (1.0.0.1)EASY-PLANNING (1.0.0.1)Basé sur les mêmes principes que MyPlanning, Easy-Planning permet de créer des plannings sous la ... Cliquez pour télécharger Easy-Planning COLLECTOR PLUS (3.00B)COLLECTOR PLUS (3.00B)COLLECTOR PLUS version 3.00B est un logiciel utilisant une base de données alimentée par :
- L... Cliquez pour télécharger COLLECTOR PLUS PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V7.4)PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V7.4)PONAMEDIA TV DEVIENS HELLLOOO FLASH
LA TV SUR VOTRE ORDINATEUR.
Toute une plateforme Multi... Cliquez pour télécharger PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO LettresFaciles 2011 (8.0.0.1)LETTRESFACILES 2011 (8.0.0.1)LettresFaciles est un logiciel facilitant la création et la rédaction de lettres types.
Son inte... Cliquez pour télécharger LettresFaciles 2011
|