Précédent   Forum des professionnels en informatique > PHP > Langage > Sessions
Sessions Forum d'entraide sur les sessions avec PHP. Avant de poster -> FAQ sessions, Cours sessions et Sources sécurité
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 30/11/2006, 16h37   #1
Membre confirmé
 
Thomas Gambier
Inscription : avril 2005
Messages : 807
Détails du profil
Informations personnelles :
Nom : Thomas Gambier
Âge : 28
Localisation : France, Drôme (Rhône Alpes)

Informations forums :
Inscription : avril 2005
Messages : 807
Points : 243
Points : 243
Par défaut [Cookies] creer un cookie

Bonjour,

Je cherche a créer un cookie pour transmettre l'id d'un client apres qu'il se soit authentifié avec la base de donnée...

Voici mon cde source:
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
 
$requete = "SELECT * FROM client WHERE mail='$mail' AND password='$password'";
$result = mysql_query($requete);
 
$nb_resultat=mysql_num_rows($result);
if($nb_resultat==0)
{
  $erreur=1;
}
else
{
	while ($row = mysql_fetch_array($result))
	{						
		$id_client = $row["id_client"];
	}
	setcookie("cookie_id_client",$id_client,time()+24*3600,"/");
	redirection("httpdocs/pages/identification2.php");
}
Donc je crée le cookie, puis je fais une redirection...
Ce que je n'arrive pas a comprendre, c'est que ma redirection fonctionne, ce qui signifie que le cookie devrait etre crée, mais le cookie n'existe pas...
Quand je vais dans les cookies dans le menu outil de mon navigateur, il n'est pas présent...

Pourquoi ca ne marche pas? Est ce que la syntaxe de création du cookie est bonne?
calitom est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 30/11/2006, 17h09   #2
Membre confirmé
 
Inscription : janvier 2004
Messages : 242
Détails du profil
Informations forums :
Inscription : janvier 2004
Messages : 242
Points : 245
Points : 245
Code :
1
2
 
setcookie("cookie_id_client",$id_client,time()+24*3600,"/",false);
Par contre j'espère que la redirection n'a pas d'impact sur le cookie, sinon fait la redirection en meta ou en javascript.
chaced est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 30/11/2006, 17h27   #3
Membre régulier
 
Avatar de titoon
 
Inscription : janvier 2005
Messages : 71
Détails du profil
Informations personnelles :
Localisation : France, Nord (Nord Pas de Calais)

Informations forums :
Inscription : janvier 2005
Messages : 71
Points : 84
Points : 84
Citation:
Envoyé par chaced
Par contre j'espère que la redirection n'a pas d'impact sur le cookie, sinon fait la redirection en meta ou en javascript.
Je confirme, il faut éviter l'utilisation du header('Location: ...') si on envoie un cookie (on peut aussi passer par un header('Set-Cookie: ...'), et là, ça fonctionne dixit la doc de php)
titoon est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 30/11/2006, 18h21   #4
Membre confirmé
 
Thomas Gambier
Inscription : avril 2005
Messages : 807
Détails du profil
Informations personnelles :
Nom : Thomas Gambier
Âge : 28
Localisation : France, Drôme (Rhône Alpes)

Informations forums :
Inscription : avril 2005
Messages : 807
Points : 243
Points : 243
C bon, j'ai réussi...
En fait c'est parce que la création du cookie se faisait apres les balise HTML et HEAD...
En fait les cookie doivent passer avant tout autre en-tête sinon il ne sont pas crées...
calitom est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 01/12/2006, 09h00   #5
Membre régulier
 
Avatar de titoon
 
Inscription : janvier 2005
Messages : 71
Détails du profil
Informations personnelles :
Localisation : France, Nord (Nord Pas de Calais)

Informations forums :
Inscription : janvier 2005
Messages : 71
Points : 84
Points : 84
Je te conseille vivement, lorsque tu développes, de mettre au début de ton script une ligne avec "error_reporting(E_ALL)" (permet de traiter toutes les erreurs). Ca t'éviterait ce genre de problème / bug
titoon 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 13h36.


 
 
 
 
Partenaires

Hébergement Web