Formation par Olivier Duffez

Formation au référencement par Olivier Duffez, créateur de WebRankInfo !
Une formule efficace alliant théorie et pratique, avec une haute disponibilité des intervenants
Cette formule a déjà convaincu plusieurs centaines d'entreprises, pourquoi pas vous ?
Réservez vite votre place en ligne (convention possible pour imputer sur le budget formation)

Formation référencement Marseille

Redirection header() en fonction de la valeur d'un cookie

Aller à la page 1, 2  Suivante
Poster un nouveau sujet Imprimer cette discussion    Forum -> Développement d'un site Web   Les dernières discussions de ce forum sont disponibles au format RSS
Voir le sujet précédent :: Voir le sujet suivant  
Auteur Message
 
Meeuuuhhh
WRInaute accro
WRInaute accro

Inscrit le: 08 Jan 2007
Messages: 1450
Localisation: Au meilleur endroit

URL permanente de ce messagePosté le : Mer Juin 11, 2008 13:25    Sujet du message: Redirection header() en fonction de la valeur d'un cookie

Bonjour,

Bon c'est la suite du topic sur les cookies et le référencement, mais là c'est plus technique alors j'ouvre un nouveau thread dans la section approprié :


Voilà, j'ai donc un disclaimer sur un site.
Ce disclaimer fonctionne avec un cookie PHP, testé sur toutes les pages. S'il n'est pas initialisé ou si sa valeur est "non", le visiteur est redirigé vers le disclaimer de index.php .
Ca, ça fonctionne.

Maintenant, je veux améliorer le système : si le gars arrive via un lien profond, il est redirigé vers l'accueil pour qu'il certifie son âge. Et ensuite, le header le renvoit sur la page par laquelle il était arrivé.
Ca, ça fonctionne pas encore.

Voilà comment j'ai fait (en partie grâce à vous, cf le topic précédent) :

En haut de toutes les pages du blog :
Code:
//on va vérifier si le visiteur est un bot, si oui, il n'a pas besoin de cookie (ou il n'indexera jamais les pages)
$moteur_tab=array("bot","Scooter","Slurp","Voila","WiseNut","Fast","Index","Teoma","Mirago","search","find","loader","archive","Spider","Crawler");
foreach($moteur_tab as $key)
// si ce n'est pas un bot, on fait le test du cookie :
if(!stristr($_SERVER['HTTP_USER_AGENT'],$key))
 {
if(!isset($_COOKIE["majeur"]) OR $_COOKIE["majeur"]=='non')
{
//on créé un cookie pour lui adjoindre la valeur de la page en cours et s'en servir dans le header du disclaimer afin de rediriger directement sur la page souhaitée au départ, en l'occurence celle visitée lors de cette instruction.
$page=$_SERVER['PHP_SELF'];
setcookie
(
"page",
"$page"
);
die(header('Location: http://www.site.com'));
}//ferme if !isset $cookie
;}//ferme if !isset stristr()
Donc ici, le gars est bien redirigé vers l'index.

Et sur l'index, je fais cela :
Code:

// avant cela, il y a les instructions pour vérifier l'âge du gars
// si tout est bon, on initialise le cookie "majeur" à "oui", et les autres pages s'afficheront alors.
setcookie
(
"majeur",
"oui"
);

//si le gars est arrivé par l'accueil, il n'y a pas de cookie page, on le redirige donc vers la page par défaut. Sinon, la valeur du header prend celle de la variable page dans le cookie (initialisée en haut des pages des blogs lors de l'instruction de test des cgu, voir bloc de code précédent)
if(!isset($_COOKIE["page"]))
{header($he);}// page par défaut

if(isset($_COOKIE["page"]))//si il y a le cookie page, ça signifie que le gars était arrivé par une page du blog et donc on le redirige (théoriquement...) sur celle-ci :
{
$page=$_COOKIE["page"];
header($page);}// page d'arrivée sur le blog
;}
Donc là, ça ne fonctionne pas. On arrive toujours sur la page par défaut.

Mais en plus, pas moyen d'afficher la valeur du cookie page. Pourtant je regarde dans le navigateur et il y est initialisé et sa valeur est bien celle de la page précédente.



Voilà, merci d'avance pour votre précieuse aide
 
Meeuuuhhh Visiter le site web du posteur
erestrebian
WRInaute impliqué
WRInaute impliqué

Inscrit le: 15 Juin 2007
Messages: 368
Localisation: Lettonie

URL permanente de ce messagePosté le : Mer Juin 11, 2008 14:07    Sujet du message: Redirection header() en fonction de la valeur d'un cookie

et en passant par une variable session?

je veux dire que tu définis la variable sur la page d'arrivée à la place du cookie. Est-ce que cela fonctionne?

c'est quoi la page par défaut? le disclaimer ou l'index quand tu dis "page par défaut"
 
erestrebian Visiter le site web du posteur
2dm
WRInaute occasionnel
WRInaute occasionnel

Inscrit le: 03 Sep 2002
Messages: 202
Localisation: Irlande - Dublin

URL permanente de ce messagePosté le : Mer Juin 11, 2008 14:43    Sujet du message: Redirection header() en fonction de la valeur d'un cookie

Déja sauf problème de lecture dans ton code (non-indenté), je pense qu'il y a une erreur sur le traitement des robots.

Tu itères sur la liste des robots autorisés et tu compare chaque élément avec le nom du visiteur/robot. :
Code:

foreach($moteur_tab as $key)
  if(!stristr($_SERVER['HTTP_USER_AGENT'],$key)){...}


Admettons que le bot "voila" passe, comme tu le teste par rapport au premier élément "bot", tu vas satisfaire ton test (!stristr()) et au final tu vas le rediriger vers la page d'accueil.

(edit : en lisant le thread original, dans le message de jeroen il parcourt le tableau et met un flag si il trouve un moteur. C'est donc ce que tu dois faire. )

Ensuite si tu dois débugguer, fait un print_r sur $_COOKIE.
Et évites les header multiples.
 
2dm Visiter le site web du posteur
jeroen
WRInaute accro
WRInaute accro

Inscrit le: 30 Aoû 2002
Messages: 2322

URL permanente de ce messagePosté le : Mer Juin 11, 2008 17:20    Sujet du message: Redirection header() en fonction de la valeur d'un cookie

Attention lors de la déclaration des cookies : ils ne sont valables que dans le répertoire de la page où ils ont été créés, sauf si tu précises autre chose :
Code:
setcookie("coo",$coo,$datedevalidite,"/");


le "/" précise que le cookie est valable depuis l'index.
 
jeroen
Meeuuuhhh
WRInaute accro
WRInaute accro

Inscrit le: 08 Jan 2007
Messages: 1450
Localisation: Au meilleur endroit

URL permanente de ce messagePosté le : Mer Juin 11, 2008 18:05    Sujet du message: Redirection header() en fonction de la valeur d'un cookie

Merci pour la remarque Jeroen.


Là j'essaie de le faire avec des sessions, mais pas moyen ça ne fonctionne pas non plus.

j'ai fait ça sur la page du disclaimer :
Code:

if(!isset($_SESSION["page"]))
{header($he);}
if(isset($_SESSION["page"]))
{
$page=$_SESSION['page'];
header($page)
;}


Là si il n'y a pas la variable de session "page", ça fonctionne bien.
Mais si elle y est, ça ne fonctionne pas.
J'ai fait un test avec un echo dans le deuxième if et ça fonctionne. J'ai affiché le contenu de la variable et elle contient bien la page visitée précédemment.
Mais le header ne fonctionne pas, même si je met en valeur une URL telle que http://www.google.com



Je pige pas. Du tout. Soupiiiiiirrrrrrr
 
Meeuuuhhh Visiter le site web du posteur
YoyoS
WRInaute accro
WRInaute accro

Inscrit le: 14 Sep 2006
Messages: 2441

URL permanente de ce messagePosté le : Mer Juin 11, 2008 18:15    Sujet du message: Redirection header() en fonction de la valeur d'un cookie

Meeuuuhhh, tu n'as pas envie de te baser sur le référant ? par exemple, s'il existe et que le visiteur n'a pas de cookie, tu fais la redirection et tu lui crées un cookie pour plus l'avoir.

Il me semble que les robots voyagent sans cookies ni référants non ?
 
YoyoS Visiter le site web du posteur
Meeuuuhhh
WRInaute accro
WRInaute accro

Inscrit le: 08 Jan 2007
Messages: 1450
Localisation: Au meilleur endroit

URL permanente de ce messagePosté le : Mer Juin 11, 2008 18:30    Sujet du message: Redirection header() en fonction de la valeur d'un cookie

Je suis pas borné à ma soluce, ceci dit je n'ai pas bien compris la tienne et je me dis qu'il ne faut plus qu'une pichenette pour que mon script fonctionne (nonobstant la partie sur la détection des robots).

Je ne vois pas pourquoi la redirection ne se fait pas alors que la condition est testée et vérifiée.
 
Meeuuuhhh Visiter le site web du posteur
2dm
WRInaute occasionnel
WRInaute occasionnel

Inscrit le: 03 Sep 2002
Messages: 202
Localisation: Irlande - Dublin

URL permanente de ce messagePosté le : Mer Juin 11, 2008 18:33    Sujet du message: Redirection header() en fonction de la valeur d'un cookie

je te l'ai dit, n'utilise qu'un seul header à la fin de ton traitement.

Code:

$page = $he;
if(isset($_SESSION["page"])){
  $page=$_SESSION['page'];
}
header($page);
 
2dm Visiter le site web du posteur
jeroen
WRInaute accro
WRInaute accro

Inscrit le: 30 Aoû 2002
Messages: 2322

URL permanente de ce messagePosté le : Mer Juin 11, 2008 18:44    Sujet du message: Redirection header() en fonction de la valeur d'un cookie

YoyoS a écrit:
Meeuuuhhh, tu n'as pas envie de te baser sur le référant ? par exemple, s'il existe et que le visiteur n'a pas de cookie, tu fais la redirection et tu lui crées un cookie pour plus l'avoir.

Il me semble que les robots voyagent sans cookies ni référants non ?


Le problème est qu'au moment où le gars à validé le disclaimer, le référent sera l'index.


Sinon la syntaxe correcte du header est celle-ci :
Code:
header("Location: http://www.nouveausite.com/");
 
jeroen
Meeuuuhhh
WRInaute accro
WRInaute accro

Inscrit le: 08 Jan 2007
Messages: 1450
Localisation: Au meilleur endroit

URL permanente de ce messagePosté le : Mer Juin 11, 2008 18:47    Sujet du message: Redirection header() en fonction de la valeur d'un cookie

Y'a rien à faire, ça m'envoie sur la page d'accueil du blog.

Pourtant quand j'affiche le contenu de $_SESSION['page'];
ça m'indique bien l'URL de la page profonde et non celle de la page d'accueil du blog.

Mais le header ne fonctionne que vers la page d'accueil du blog.
 
Meeuuuhhh Visiter le site web du posteur
jeroen
WRInaute accro
WRInaute accro

Inscrit le: 30 Aoû 2002
Messages: 2322

URL permanente de ce messagePosté le : Mer Juin 11, 2008 18:58    Sujet du message: Redirection header() en fonction de la valeur d'un cookie

jeroen a écrit:
Sinon la syntaxe correcte du header est celle-ci :
Code:
header("Location: http://www.nouveausite.com/");
 
jeroen
Meeuuuhhh
WRInaute accro
WRInaute accro

Inscrit le: 08 Jan 2007
Messages: 1450
Localisation: Au meilleur endroit

URL permanente de ce messagePosté le : Mer Juin 11, 2008 19:13    Sujet du message: Redirection header() en fonction de la valeur d'un cookie

Oui je l'ai changé, mais ça ne fonctionne pas.
 
Meeuuuhhh Visiter le site web du posteur
Meeuuuhhh
WRInaute accro
WRInaute accro

Inscrit le: 08 Jan 2007
Messages: 1450
Localisation: Au meilleur endroit

URL permanente de ce messagePosté le : Mer Juin 11, 2008 19:26    Sujet du message: Redirection header() en fonction de la valeur d'un cookie

Bon par contre là j'ai essayé ça et la redirection est ok :
Code:

$page = $he;
if(isset($_SESSION["page"]))
{$page="http://www.site.com/blog/index.php/2008/06/10/1-first-post";}
header("location: $page");


Je me demande si ce n'est pas parce que l'url récupérée par PHP_SELF commence par / ce qui donne(rait) dans l'url un //blog

Mais quand j'essaie dans la barre de navigation de taper l'url avec //, ça fonctionne, je ne suis pas pour autant redirigé vers l'accueil du blog (sans quoi le résultat eut été trompeur, l'erreur ne venant pas du header)

Bon, j'essaie autre chose, je vais récupérer l'url dans un champ post, sur la page du disclaimer. Je reviens, merci de votre aide.


Dernière édition par Meeuuuhhh le Mer Juin 11, 2008 19:36; édité 1 fois
 
Meeuuuhhh Visiter le site web du posteur
jeroen
WRInaute accro
WRInaute accro

Inscrit le: 30 Aoû 2002
Messages: 2322

URL permanente de ce messagePosté le : Mer Juin 11, 2008 19:28    Sujet du message: Redirection header() en fonction de la valeur d'un cookie

Tu n'a pas d'erreur php ?
Essaie de faire un echo $page juste avant le header, et donne le résultat, ainsi que ton code exact du header()
 
jeroen
Meeuuuhhh
WRInaute accro
WRInaute accro

Inscrit le: 08 Jan 2007
Messages: 1450
Localisation: Au meilleur endroit

URL permanente de ce messagePosté le : Mer Juin 11, 2008 19:33    Sujet du message: Redirection header() en fonction de la valeur d'un cookie

Je l'ai fait et l'url de la page s'affiche bien, la condition est vérifiée, c'est ça que je pige pas.

Je me demande si ce n'est pas dû à la syntaxe de la variable de session, car quand j'avais regardé dans le cookie, l'url était du genre /blog/index.php%$var2008/06/10/&var%first-post

Bref un gros truc bien crade, car l'url n'était pas rewritée. Peut-être est-ce celà qui fait bugger le header ?
 
Meeuuuhhh Visiter le site web du posteur
 
Montrer les messages depuis:   
Revenir en haut    Forum -> Développement d'un site Web Toutes les heures sont au format GMT + 1 Heure
Page 1 sur 2 - Aller à la page 1, 2  Suivante
Connexion
Nom d'utilisateur:    Mot de passe:      Se connecter automatiquement à chaque visite    

CLIQUEZ ICI pour vous inscrire à WebRankInfo (forum, annuaire, outils...)

Connexion

© 2001-2005 phpBB Group, support français
Personnalisation : WebRankInfo ™


 ODP  Firefox  Alsacreations  annuaire webmaster Yagoort