Précédent   Forum des professionnels en informatique > PHP > Outils
Outils Forum d'entraide sur les outils pour développeurs PHP : EDI, installation, administration... Avant de poster : FAQ outils, toutes les FAQ PHP et les comparatifs
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 13/10/2006, 15h22   #1
Membre extrêmement actif
 
Avatar de lodan
 
Inscription : juin 2006
Messages : 1 804
Détails du profil
Informations forums :
Inscription : juin 2006
Messages : 1 804
Points : 587
Points : 587
Par défaut [Configuration] preg_match acceptant apostrophe

Bonjour,

J'ai une fonction de contrôle des caractères pour les libellés

Code :
1
2
3
4
function okTexte($texte)
{
   	return preg_match("`^[a-zA-Z0-9éèêùûôçàâî°_\-\(\),';:?.!/\%:& ]*$`",$texte);
}
Lorsque j'écris : "c'est l'identité"

J'ai un message d'erreur à cause des " ' ", pourtant j'ai mis que je l'acceptais.
Est-ce un caractère qui demande quelque précaution ?

Merci d'avance
__________________
Y a pas, plus on fait, plus on sait. Plus on cherche, plus on sait chercher. Maintenant quant à trouver, c'est autre chose.
lodan est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 13/10/2006, 15h40   #2
Expert Confirmé
 
Avatar de trotters213
 
Inscription : janvier 2005
Messages : 2 572
Détails du profil
Informations personnelles :
Âge : 26
Localisation : France, Gard (Languedoc Roussillon)

Informations forums :
Inscription : janvier 2005
Messages : 2 572
Points : 2 605
Points : 2 605

Perso que je fasse comme tu dis ou comme ça
Code :
return preg_match('`^[a-zA-Z0-9éèêùûôçàâî°_\-\(\),\';:?.!/\%:& ]*$`',"c'est l'identité");
ça marche très bien, ça renvoit "1".
Ton problème ne vient pas d'autres part?
__________________
Pensez au tag
Les règles du Forum

Dev. Web : FAQ (X)HTML/CSS | Tutos (X)HTML | Tutos CSS

PHP : FAQ PHP | Tutos PHP | Benchmark PHP 5

SQL : Cours SQL
trotters213 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 13/10/2006, 16h05   #3
Membre extrêmement actif
 
Avatar de lodan
 
Inscription : juin 2006
Messages : 1 804
Détails du profil
Informations forums :
Inscription : juin 2006
Messages : 1 804
Points : 587
Points : 587
Je vais creuser la chose.

Dès que je retire " ' ", c'est bon et je n'ai que cela comme contrôle.
__________________
Y a pas, plus on fait, plus on sait. Plus on cherche, plus on sait chercher. Maintenant quant à trouver, c'est autre chose.
lodan est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 13/10/2006, 16h13   #4
En attente de confirmation mail
 
Inscription : juin 2002
Messages : 6 164
Détails du profil
Informations forums :
Inscription : juin 2002
Messages : 6 164
Points : 6 404
Points : 6 404
Est-ce que vous testez des données qui proviennent des méthodes POST/GET/COOKIE ? Si oui, les magic_quotes ne sont pas activées sur votre serveur par hasard ? Il y aurait donc dans ce cas un backslash devant votre apostrophe.


Julp.
julp est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 13/10/2006, 16h19   #5
Membre extrêmement actif
 
Avatar de lodan
 
Inscription : juin 2006
Messages : 1 804
Détails du profil
Informations forums :
Inscription : juin 2006
Messages : 1 804
Points : 587
Points : 587
Il y a bien les magic_quotes d'activés

Mais je l'ai gère

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
if (!empty($_POST)) 
	{
	require_once("../inc/valRetour.php");
	require_once("../inc/valButton.php");
 
// Traitement des données en provenance du formulaire pour protection
$indice=array_keys($_POST);
foreach($indice as $i)
{
	$_POST[$i]=quote_post($_POST[$i]);
}
	// Contrôle des champs à mettre à jour
	require_once("../inc/ctrReqSql.php");
Dans "quote_post" je fais :

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
// Protège la variable en entrée de script
function quote_post($value)
{
	if (is_numeric($value))
	{ 
         return $value;
    }
    elseif(is_array($value))
    {
    	foreach($value as $k => $v)
    	{
    		if (is_numeric($k))
    		{
    			return $value;
        	}
        	$value[$k] = stripslashes($v);
    	}
    }
    else
    {
    	if (get_magic_quotes_gpc())
            $value = stripslashes($value);
   }
   return $value;
}
Et mon controle avec le " ' " se fait dans "ctrReqSql.php"
__________________
Y a pas, plus on fait, plus on sait. Plus on cherche, plus on sait chercher. Maintenant quant à trouver, c'est autre chose.
lodan est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 13/10/2006, 17h23   #6
Membre chevronné
 
Avatar de kankrelune
 
Inscription : décembre 2005
Messages : 766
Détails du profil
Informations forums :
Inscription : décembre 2005
Messages : 766
Points : 745
Points : 745
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
// Protège la variable en entrée de script
function quote_post($value)
{
	if (is_numeric($value))
	{ 
         return $value;
    }
    elseif(is_array($value))
    {
    	foreach($value as $k => $v)
    	{
    		if (is_numeric($k))
    		{
    			return $value;
        	}
        	$value[$k] = stripslashes($v);
    	}
    }
    else
    {
    	if (get_magic_quotes_gpc())
            $value = stripslashes($value);
   }
   return $value;
}


Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
 
// Protège la variable en entrée de script
function quote_post($value)
{
     if (is_numeric($value))
	 return $value;
     elseif(is_array($value))
     {
    	foreach($value as $k => $v)
    	    $value[$k] = quote_post($v);
     }
     else
     {
    	if (get_magic_quotes_gpc())
            $value = stripslashes($value);
     }
     return $value;
}
Mais bon je vois pas l'interet de faire ça en début de script hormis celui de perdre du temps... .. .

@ tchaOo°
kankrelune est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 13/10/2006, 19h08   #7
Membre extrêmement actif
 
Avatar de lodan
 
Inscription : juin 2006
Messages : 1 804
Détails du profil
Informations forums :
Inscription : juin 2006
Messages : 1 804
Points : 587
Points : 587
Ben si je ne fais pas ça c'est un vrai bordel dans mes champs de contrôle et dans ce qui est mis à jour dans ma base.
__________________
Y a pas, plus on fait, plus on sait. Plus on cherche, plus on sait chercher. Maintenant quant à trouver, c'est autre chose.
lodan est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 13/10/2006, 19h21   #8
Rédacteur
 
Avatar de Yogui
 
Homme Guillaume Rossolini
Directeur technique
Inscription : février 2004
Messages : 13 720
Détails du profil
Informations personnelles :
Nom : Homme Guillaume Rossolini
Localisation : France

Informations professionnelles :
Activité : Directeur technique

Informations forums :
Inscription : février 2004
Messages : 13 720
Points : 17 355
Points : 17 355
Salut

Si le problème vient des magic_quotes, tu peux utiliser un fichier .htaccess pour modifier la configuration PHP avant l'exécution du script. Il y a une directive pour changer les options de php.ini, je ne l'ai plus en tête.

J'en profite pour caser cet article : http://g-rossolini.developpez.com/tu...ns-regulieres/
__________________
Mes articles - Zend Certified Engineer (PHP + Zend Framework)
Ressources PHP - Ressources Zend Framework
Yogui est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 13/10/2006, 22h08   #9
Membre extrêmement actif
 
Avatar de lodan
 
Inscription : juin 2006
Messages : 1 804
Détails du profil
Informations forums :
Inscription : juin 2006
Messages : 1 804
Points : 587
Points : 587
Citation:
Envoyé par julp
Est-ce que vous testez des données qui proviennent des méthodes POST/GET/COOKIE ? Si oui, les magic_quotes ne sont pas activées sur votre serveur par hasard ? Il y aurait donc dans ce cas un backslash devant votre apostrophe.


Julp.
Bon c'est bien un "\" qui traîne, je vais donc faire un "stripslashes"

Merci, j'avais mal placé mon echo de contrôle.
__________________
Y a pas, plus on fait, plus on sait. Plus on cherche, plus on sait chercher. Maintenant quant à trouver, c'est autre chose.
lodan est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 13/10/2006, 22h26   #10
Membre extrêmement actif
 
Avatar de lodan
 
Inscription : juin 2006
Messages : 1 804
Détails du profil
Informations forums :
Inscription : juin 2006
Messages : 1 804
Points : 587
Points : 587
Non, j'ai trouvé, je ne sais pas en core comment le résoudre, mais c'est en faite le saut de ligne.

Je suis dans un champ "text" et en saisissant, je fais "enter" pour sauter une ligne et c'est lui qui n'est pas accepté.

Pas trouver dans la doc mise en lien par yogui, mais on cherche on cherche
__________________
Y a pas, plus on fait, plus on sait. Plus on cherche, plus on sait chercher. Maintenant quant à trouver, c'est autre chose.
lodan est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 14/10/2006, 08h06   #11
Rédacteur
 
Avatar de Yogui
 
Homme Guillaume Rossolini
Directeur technique
Inscription : février 2004
Messages : 13 720
Détails du profil
Informations personnelles :
Nom : Homme Guillaume Rossolini
Localisation : France

Informations professionnelles :
Activité : Directeur technique

Informations forums :
Inscription : février 2004
Messages : 13 720
Points : 17 355
Points : 17 355
Dans un contrôle input de type "text", la touhe Entrée du clavier sert à valider le formulaire. Pour passer une ligne, il te faut utiliser un contrôle textarea.
Il me semble l'avoir traité dans un autre tuto : Les formulaires et PHP
__________________
Mes articles - Zend Certified Engineer (PHP + Zend Framework)
Ressources PHP - Ressources Zend Framework
Yogui est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 14/10/2006, 08h56   #12
Membre extrêmement actif
 
Avatar de lodan
 
Inscription : juin 2006
Messages : 1 804
Détails du profil
Informations forums :
Inscription : juin 2006
Messages : 1 804
Points : 587
Points : 587
Citation:
Envoyé par Yogui
Dans un contrôle input de type "text", la touhe Entrée du clavier sert à valider le formulaire. Pour passer une ligne, il te faut utiliser un contrôle textarea.
Il me semble l'avoir traité dans un autre tuto : Les formulaires et PHP
J'ai fait ceci :
Code :
if(!okTexte(nl2br($_POST["dec_commentaire"])))
Mais cela n'a rien changé

J'ai mis 2 echo avant mon contrôle pour voir ce que cela donnait :

Code :
1
2
3
4
echo $_POST["dec_commentaire"];
echo "<p>";
echo nl2br($_POST["dec_commentaire"]);
if(!okTexte(nl2br($_POST["dec_commentaire"])))
Le 1er donne :

Code :
On test le saut de ligne. Comme ceci
Le 2ème

Code :
1
2
On test le saut de ligne.
Comme ceci
C'est ok pour la présentation, mais pas pour le contrôle des caractères interdits.
__________________
Y a pas, plus on fait, plus on sait. Plus on cherche, plus on sait chercher. Maintenant quant à trouver, c'est autre chose.
lodan est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 14/10/2006, 09h03   #13
Rédacteur
 
Avatar de Yogui
 
Homme Guillaume Rossolini
Directeur technique
Inscription : février 2004
Messages : 13 720
Détails du profil
Informations personnelles :
Nom : Homme Guillaume Rossolini
Localisation : France

Informations professionnelles :
Activité : Directeur technique

Informations forums :
Inscription : février 2004
Messages : 13 720
Points : 17 355
Points : 17 355
Et si tu ajoutes \s dans les caractères interdits ?
__________________
Mes articles - Zend Certified Engineer (PHP + Zend Framework)
Ressources PHP - Ressources Zend Framework
Yogui est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 14/10/2006, 10h24   #14
Membre extrêmement actif
 
Avatar de lodan
 
Inscription : juin 2006
Messages : 1 804
Détails du profil
Informations forums :
Inscription : juin 2006
Messages : 1 804
Points : 587
Points : 587
Là c'est top, c'est tout à fait ça.

Merci beaucoup
__________________
Y a pas, plus on fait, plus on sait. Plus on cherche, plus on sait chercher. Maintenant quant à trouver, c'est autre chose.
lodan est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 06h31.


 
 
 
 
Partenaires

Hébergement Web