Parse error: syntax error, unexpected '' et functions accepter/r
Résolu
Zakarya93
Messages postés
984
Date d'inscription
Statut
Membre
Dernière intervention
-
Zakarya93 Messages postés 984 Date d'inscription Statut Membre Dernière intervention -
Zakarya93 Messages postés 984 Date d'inscription Statut Membre Dernière intervention -
Bonjour,
1/ J'ai cette erreur que je n'arrive pas à décrypter : Parse error: syntax error, unexpected '' (T_ENCAPSED_AND_WHITESPACE), expecting identifier (T_STRING) or variable (T_VARIABLE) or number (T_NUM_STRING) in C:\wamp\www\rs\pages\invitations.php on line 17
2/ sachant que le code mysl_ est :
c'est bon si je mets :
3/ et pour le "refuser invitation" que faudrait il simplement que je modifie ?
Merci d'avance ! :)
Bonne nuit
1/ J'ai cette erreur que je n'arrive pas à décrypter : Parse error: syntax error, unexpected '' (T_ENCAPSED_AND_WHITESPACE), expecting identifier (T_STRING) or variable (T_VARIABLE) or number (T_NUM_STRING) in C:\wamp\www\rs\pages\invitations.php on line 17
<?php include('functions/membre.func.php'); include('body/header.php'); include('body/menu.php'); ?> <h3>Vos invitations</h3> <?php $invitations = recup_invitations(); if(count($invitations)>0){ foreach($invitations as $invitation) { if($invitation['active'] == 0) { echo "<img src='avatar/".$invitation['avatar']."'height='100' width='100' alt='avatar'>"; echo "<div class='error'> ".$invitation['pseudo_exp']." a voulu vous ajouter comme ami(e)<br />"; echo " <a href='index.php?page=accepter&pseudo= echo $invitation['pseudo_exp']; '>Accepter |</a><a href='index.php?page=refuser&pseudo= echo $invitation['pseudo_exp']; '> Refuser</a>"; echo "</div>"; } }else{ <div class='success'>Vous êtes désormais ami(e) avec echo $invitation['pseudo_exp']; </div> } echo "<div class='error'>Vous n'avez pas d'invitations</div>"; } ?>
2/ sachant que le code mysl_ est :
<?php // la fonction qui v accepter l'invitation function accepter_invitation() { mysql_query(" UPDATE amis SET active=1, date_confirmation=NOW();() WHERE pseudo_exp'{$_GET['pseudo']}' AND pseudo_dest='{$SESSION['pseudo']}' "); } ?>
c'est bon si je mets :
<?php //la function qui va accepter l'invitation function accepter_invitation(); global $bdd; //récupération des variables PROPREMENT ! $pseudo_exp = isset($_SESSION['pseudo'])?$_SESSION['pseudo']:NULL; $pseudo_dest = isset($_GET['pseudo'])?$_GET['pseudo']:NULL; $result=0; if($pseudo_exp && $pseudo_dest){ $sql = "UPDATE FROM amis SET active=1, date_confirmation=NOW WHERE (pseudo_exp = :session_pseudo AND pseudo_dest = :get_pseudo)"; // je place les params dans une variable avant de l'utiliser : $params = array('session_pseudo' => $pseudo_exp , 'get_pseudo' => $pseudo_dest); $query = $bdd->prepare($sql); $query ->execute($params); $requete = $query->fetchall(); } // le return return $result; }
3/ et pour le "refuser invitation" que faudrait il simplement que je modifie ?
Merci d'avance ! :)
Bonne nuit
A voir également:
- Parse error: syntax error, unexpected '' et functions accepter/r
- Cmos checksum error ✓ - Forum Carte-mère/mémoire
- Playback error reconnect in 3s (1/5) francais - Forum Box et Streaming vidéo
- Error 1962 ✓ - Forum PC fixe
- Whea error occt - Forum Processeur
- A javascript error occurred in the main process - Forum Matériel & Système
19 réponses
Tu as des ECHO ... alors que tu es déjà dans un ECHO
(ça fait déjà plusieurs fois que tu as ce même genre de pb..... tu pourrais réussir à corriger par toi même à force... non ?)
A changer par :
(ça fait déjà plusieurs fois que tu as ce même genre de pb..... tu pourrais réussir à corriger par toi même à force... non ?)
echo " <a href='index.php?page=accepter&pseudo= echo $invitation['pseudo_exp']; '>Accepter |</a><a href='index.php?page=refuser&pseudo= echo $invitation['pseudo_exp']; '> Refuser</a>";
A changer par :
echo " <a href='index.php?page=accepter&pseudo=".$invitation['pseudo_exp']."'>Accepter |</a><a href='index.php?page=refuser&pseudo=".$invitation['pseudo_exp']."'> Refuser</a>";
Pour le 2/
NB :
Tu ne fais un FETCHALL .. que sur une requête SELECT
Et tu fais un RETURN dans ta fonction... si tu dois retourner quelque chose.. hors ici... tu fais un UPDATE... tu ne retourne rien.
<?php //la function qui va accepter l'invitation function accepter_invitation(); global $bdd; //récupération des variables PROPREMENT ! $pseudo_exp = isset($_SESSION['pseudo'])?$_SESSION['pseudo']:NULL; $pseudo_dest = isset($_GET['pseudo'])?$_GET['pseudo']:NULL; if($pseudo_exp && $pseudo_dest){ $sql = "UPDATE amis SET active=1 , date_confirmation=NOW WHERE (pseudo_exp = :session_pseudo AND pseudo_dest = :get_pseudo)"; // je place les params dans une variable avant de l'utiliser : $params = array(':session_pseudo' => $pseudo_exp , ':get_pseudo' => $pseudo_dest); $query = $bdd->prepare($sql); $query ->execute($params); } }
NB :
Tu ne fais un FETCHALL .. que sur une requête SELECT
Et tu fais un RETURN dans ta fonction... si tu dois retourner quelque chose.. hors ici... tu fais un UPDATE... tu ne retourne rien.
3/ et pour le "refuser invitation" que faudrait il simplement que je modifie ?
Je pense que dans le cas d'un refus... tu supprime la demande et donc.. il suffirait juste de changer La requête...
$sql = "DELETE FROM amis WHERE (pseudo_exp = :session_pseudo AND pseudo_dest = :get_pseudo)";
Merci infiniement ! ceci montre bien la mauvaise qualité du tuto qui m'est proposé...content d'avoir pu accéder à vos services :)
trève de bavardages, j'ai ceci : Parse error: syntax error, unexpected 'else' (T_ELSE) in C:\wamp\www\rs\pages\invitations.php on line 20
trève de bavardages, j'ai ceci : Parse error: syntax error, unexpected 'else' (T_ELSE) in C:\wamp\www\rs\pages\invitations.php on line 20
<?php include('functions/membre.func.php'); include('body/header.php'); include('body/menu.php'); ?> <h3>Vos invitations</h3> <?php $invitations = recup_invitations(); if(count($invitations)>0){ foreach($invitations as $invitation) { if($invitation['active'] == 0) { echo "<img src='avatar/".$invitation['avatar']."'height='100' width='100' alt='avatar'>"; echo "<div class='error'> ".$invitation['pseudo_exp']." a voulu vous ajouter comme ami(e)<br />"; echo " <a href='index.php?page=accepter&pseudo=".$invitation['pseudo_exp']."'>Accepter |</a><a href='index.php?page=refuser&pseudo=".$invitation['pseudo_exp']."'> Refuser</a>"; echo "</div>"; } }else{ echo " <div class='success'>Vous êtes désormais ami(e) avec ".$invitation['pseudo_exp']." </div>"; } echo "<div class='error'>Vous n'avez pas d'invitations</div>"; } ?>
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
Correction :
Mais le problème c'est que j'ai :
jean a voulu vous ajouter comme ami(e)
Accepter | Refuser
Vous êtes désormais ami(e) avec jean
qui s'affiche c'est bizzare :(
<?php include('functions/membre.func.php'); include('body/header.php'); include('body/menu.php'); ?> <h3>Vos invitations</h3> <?php $invitations = recup_invitations(); if(count($invitations)>0){ foreach($invitations as $invitation) { if($invitation['active'] == 0) { echo "<img src='avatar/".$invitation['avatar']."'height='100' width='100' alt='avatar'>"; echo "<div class='error'> ".$invitation['pseudo_exp']." a voulu vous ajouter comme ami(e)<br />"; echo " <a href='index.php?page=accepter&pseudo=".$invitation['pseudo_exp']."'>Accepter |</a><a href='index.php?page=refuser&pseudo=".$invitation['pseudo_exp']."'> Refuser</a>"; echo "</div>"; } } echo" <div class='success'>Vous êtes désormais ami(e) avec ".$invitation['pseudo_exp']." </div>"; } else{ echo "<div class='error'>Vous n'avez pas d'invitations</div>"; } ?>
Mais le problème c'est que j'ai :
jean a voulu vous ajouter comme ami(e)
Accepter | Refuser
Vous êtes désormais ami(e) avec jean
qui s'affiche c'est bizzare :(
Attends, je crois que ca vient de moi, essaye plutôt ça :
Ce n'était pas une accolade en trop, mais une en moins ton souci !
<?php include('functions/membre.func.php'); include('body/header.php'); include('body/menu.php'); ?> <h3>Vos invitations</h3> <?php $invitations = recup_invitations(); if(count($invitations)>0) { foreach($invitations as $invitation) { if($invitation['active'] == 0) { echo "<img src='avatar/".$invitation['avatar']."'height='100' width='100' alt='avatar'>"; echo "<div class='error'> ".$invitation['pseudo_exp']." a voulu vous ajouter comme ami(e)<br />"; echo " <a href='index.php?page=accepter&pseudo=".$invitation['pseudo_exp']."'>Accepter |</a><a href='index.php?page=refuser&pseudo=".$invitation['pseudo_exp']."'> Refuser</a>"; echo "</div>"; } } } else{ echo " <div class='success'>Vous êtes désormais ami(e) avec ".$invitation['pseudo_exp']." </div>"; } echo "<div class='error'>Vous n'avez pas d'invitations</div>"; } ?>
Ce n'était pas une accolade en trop, mais une en moins ton souci !
Mea culpa, il ya un truc qui ne va pas. Reprends ce que tu veux obtenir :
Si invitation n'est pas vide, on parcours le tableau en affichant les demande actives et les demandes acceptées. (if...else)
Sinon, on affiche "pas d'invitations".
Comme il y a deux "sinon", cela implique deux else et tu n'en a qu'un.
Je te laisse chercher un peu comment résoudre l'erreur... (si besoin, je te donnerai la solution)
Si invitation n'est pas vide, on parcours le tableau en affichant les demande actives et les demandes acceptées. (if...else)
Sinon, on affiche "pas d'invitations".
Comme il y a deux "sinon", cela implique deux else et tu n'en a qu'un.
Je te laisse chercher un peu comment résoudre l'erreur... (si besoin, je te donnerai la solution)
<?php //la function qui va refuser l'invitation function refuser_invitation() { global $bdd; //récupération des variables PROPREMENT ! $pseudo_exp = isset($_SESSION['pseudo'])?$_SESSION['pseudo']:NULL; $pseudo_dest = isset($_GET['pseudo'])?$_GET['pseudo']:NULL; if($pseudo_exp && $pseudo_dest){ $sql = $sql = "DELETE FROM amis WHERE (pseudo_exp = :pseudo_exp AND pseudo_dest = :get_pseudo) // je place les params dans une variable avant de l'utiliser : $params = array(':session_pseudo' => $pseudo_exp , ':get_pseudo' => $pseudo_dest); $query = $bdd->prepare($sql); $query ->execute($params); $result=1; } else { $result=0; } // le return : // si result == 0 on retourne false .. sinon true : return $result == 0 ? 0 : 1 ; } ?>
c'est pourtant ce qui est déjà marqué non ?
Ensuite.. tu as encore des erreurs dans les variables de ta requête ... + une apostrophe manquante..
bref:
testes ceci :
bref:
testes ceci :
//la function qui va refuser l'invitation function refuser_invitation() { global $bdd; //récupération des variables PROPREMENT ! $pseudo_exp = isset($_SESSION['pseudo'])?$_SESSION['pseudo']:NULL; $pseudo_dest = isset($_GET['pseudo'])?$_GET['pseudo']:NULL; $return = 0; if($pseudo_exp && $pseudo_dest){ $sql = $sql = "DELETE FROM amis WHERE pseudo_exp = :pseudo_exp AND pseudo_dest = :pseudo_dest"; // je place les params dans une variable avant de l'utiliser : $params = array(':pseudo_exp' => $pseudo_exp , ':pseudo_dest' => $pseudo_dest); $query = $bdd->prepare($sql); $query ->execute($params); $return = 1; } return $return; }
On va ajouter un bloc TRY / CATCH ... à ta requête pour s'assurer que ce n'est pas elle qui poserait problème
Cordialement,
Jordane
//la function qui va refuser l'invitation function refuser_invitation() { global $bdd; //récupération des variables PROPREMENT ! $pseudo_exp = isset($_SESSION['pseudo'])?$_SESSION['pseudo']:NULL; $pseudo_dest = isset($_GET['pseudo'])?$_GET['pseudo']:NULL; $return = 0; if($pseudo_exp && $pseudo_dest){ $sql = $sql = "DELETE FROM amis WHERE pseudo_exp = :pseudo_exp AND pseudo_dest = :pseudo_dest"; // je place les params dans une variable avant de l'utiliser : $params = array(':pseudo_exp' => $pseudo_exp , ':pseudo_dest' => $pseudo_dest); try{ $query = $bdd->prepare($sql); $query ->execute($params); $return = 1; }catch(Exception $e) { echo "<br>".$e->getMessage()."<br>"; echo "<br>params : <br>"; print_r($params); } } return $return; }
Cordialement,
Jordane
Donc.. voici le code corrigé (avec le else manquant .. et un peu de debug ! )
<?php require_once('functions/membre.func.php'); include_once('body/header.php'); include_once('body/menu.php'); ?> <h3>Vos invitations</h3> <?php $invitations = recup_invitations(); //--------------------------------// //le temps des tests : //--------------------------------// echo "<br> Invitations :<br>"; print_r($invitations); //--------------------------------// if(count($invitations)>0){ foreach($invitations as $R) { $invit_exp = $R['pseudo_exp']; $avatar = $R['avatar']; if($R['active'] == 0){ echo "<img src='avatar/$avatar' height='100' width='100' alt='avatar'></img>"; echo "<div class='error'> ".$invitation['pseudo_exp']." a voulu vous ajouter comme ami(e)<br />"; echo " <a href='index.php?page=accepter&pseudo=$invit_exp'>Accepter</a>|<a href='index.php?page=refuser&pseudo=$invit_exp'> Refuser</a>"; echo "</div>"; } }else { echo" <div class='success'>Vous êtes désormais ami(e) avec $invit_exp </div>"; } } else { echo "<div class='error'>Vous n'avez pas d'invitations</div>"; }
Ouppsss...
ça devrait être mieux :
Cordialement,
Jordane
ça devrait être mieux :
<?php require_once('functions/membre.func.php'); include_once('body/header.php'); include_once('body/menu.php'); ?> <h3>Vos invitations</h3> <?php $invitations = recup_invitations(); if(count($invitations)>0){ foreach($invitations as $R) { $invit_exp = $R['pseudo_exp']; $avatar = $R['avatar']; $active = $R['active']; if($active == 0){ echo "<img src='avatar/$avatar' height='100' width='100' alt='avatar'></img>"; echo "<div class='error'>"; echo " $invit_exp a voulu vous ajouter comme ami(e)<br />"; echo " <a href='index.php?page=accepter&pseudo=$invit_exp'>Accepter</a>|<a href='index.php?page=refuser&pseudo=$invit_exp'> Refuser</a>"; echo "</div>"; }else { echo" <div class='success'>Vous êtes désormais ami(e) avec $invit_exp </div>"; }//fin du IF active } // fin du FOREACH } else { echo "<div class='error'>Vous n'avez pas d'invitations</div>"; }//fin du if(count
Cordialement,
Jordane
Donc.. visiblement...
tu es dans le cas :
Ce n'est pas bon ??
tu es dans le cas :
if($active == 0){ echo "<img src='avatar/$avatar' height='100' width='100' alt='avatar'></img>"; echo "<div class='error'>"; echo " $invit_exp a voulu vous ajouter comme ami(e)<br />"; echo " <a href='index.php?page=accepter&pseudo=$invit_exp'>Accepter</a>|<a href='index.php?page=refuser&pseudo=$invit_exp'> Refuser</a>"; echo "</div>";
Ce n'est pas bon ??
On va commencer par la page "accepter"
Que contient cette page (quel code ) ?
Que contient cette page (quel code ) ?
J'ai : Invitations :
Array ( [0] => Array ( [pseudo_exp] => jean [0] => jean [date_invitation] => 2015-06-18 23:01:52 [1] => 2015-06-18 23:01:52 [active] => 0 [2] => 0 [avatar] => defaut.jpg [3] => defaut.jpg ) )
code function :
Array ( [0] => Array ( [pseudo_exp] => jean [0] => jean [date_invitation] => 2015-06-18 23:01:52 [1] => 2015-06-18 23:01:52 [active] => 0 [2] => 0 [avatar] => defaut.jpg [3] => defaut.jpg ) )
code function :
<?php //la function qui va accepter l'invitation function accepter_invitation() { global $bdd; //récupération des variables PROPREMENT ! $pseudo_exp = isset($_SESSION['pseudo'])?$_SESSION['pseudo']:NULL; $pseudo_dest = isset($_GET['pseudo'])?$_GET['pseudo']:NULL; if($pseudo_exp && $pseudo_dest){ $sql = "UPDATE amis SET active=1 , date_confirmation=NOW WHERE (pseudo_exp = :session_pseudo AND pseudo_dest = :get_pseudo)"; // je place les params dans une variable avant de l'utiliser : $params = array(':session_pseudo' => $pseudo_exp , ':get_pseudo' => $pseudo_dest); $query = $bdd->prepare($sql); $query ->execute($params); } }
ok
Maintenant... change le code de ta page accepter comme ceci :
Puis vas dans ta BDD ... et regardes comment est le champ ACTIVE.
Si il est passé à 1 ... remets le à 0 ...
puis Modifie le code de ta fonction ainsi.
et retestes.
Maintenant... change le code de ta page accepter comme ceci :
<?php $accepter = accepter_invitation(); if($accepter){ echo " Invitation acceptée !"; }else{ echo "Erreur !"; } //header("Location:index.php?page=profile&pseudo=".$_GET['pseudo']); ?>
Puis vas dans ta BDD ... et regardes comment est le champ ACTIVE.
Si il est passé à 1 ... remets le à 0 ...
puis Modifie le code de ta fonction ainsi.
<?php //la function qui va accepter l'invitation function accepter_invitation() { global $bdd; //récupération des variables PROPREMENT ! $pseudo_exp = isset($_SESSION['pseudo'])?$_SESSION['pseudo']:NULL; $pseudo_dest = isset($_GET['pseudo'])?$_GET['pseudo']:NULL; $return = 0; if($pseudo_exp && $pseudo_dest){ $sql = "UPDATE amis SET active=1 ,date_confirmation=NOW WHERE pseudo_exp = :session_pseudo AND pseudo_dest = :get_pseudo"; // je place les params dans une variable avant de l'utiliser : $params = array(':session_pseudo' => $pseudo_exp , ':get_pseudo' => $pseudo_dest); try{ $query = $bdd->prepare($sql); $query ->execute($params); $return = 1; }catch(Exception $e) { echo "<br>".$e->getMessage()."<br>"; echo "<br>params : <br>"; print_r($params); } } return $return; }
et retestes.
Tu peux modifier ton code par celui-ci (j'ai ajouté un print)
et relancer ta page pour voir ce que ça te donne ?
et relancer ta page pour voir ce que ça te donne ?
<?php //la function qui va accepter l'invitation function accepter_invitation() { global $bdd; //récupération des variables PROPREMENT ! $pseudo_exp = isset($_SESSION['pseudo'])?$_SESSION['pseudo']:NULL; $pseudo_dest = isset($_GET['pseudo'])?$_GET['pseudo']:NULL; $return = 0; if($pseudo_exp && $pseudo_dest){ $sql = "UPDATE amis SET active=1 ,date_confirmation=NOW WHERE pseudo_exp = :session_pseudo AND pseudo_dest = :get_pseudo"; // je place les params dans une variable avant de l'utiliser : $params = array(':session_pseudo' => $pseudo_exp , ':get_pseudo' => $pseudo_dest); // le temps des tests echo "<br>params : <br>"; print_r($params); try{ $query = $bdd->prepare($sql); $query ->execute($params); $return = 1; }catch(Exception $e) { echo "<br>".$e->getMessage()."<br>"; echo "<br>params : <br>"; print_r($params); } } return $return; }
J'ai l'impression que tu as inversé les deux variables dans le where...
car là ... celui qui doit accepter la demande... est celui qui l'a reçu .... et donc ... celui qui consulte la page.
Donc : Pseudo_dest c'est SESSION['pseudo']
et pseudo_exp => $_GET['pseudo']
A modifier par :
car là ... celui qui doit accepter la demande... est celui qui l'a reçu .... et donc ... celui qui consulte la page.
Donc : Pseudo_dest c'est SESSION['pseudo']
et pseudo_exp => $_GET['pseudo']
WHERE pseudo_exp = :session_pseudo AND pseudo_dest = :get_pseudo
A modifier par :
WHERE pseudo_exp = :get_pseudo AND pseudo_dest = :session_pseudo
Parse error: syntax error, unexpected '>' in C:\wamp\www\rs\functions\accepter.func.php on line 22
<?php //la function qui va accepter l'invitation function accepter_invitation() { global $bdd; //récupération des variables PROPREMENT ! $pseudo_exp = isset($_SESSION['pseudo'])?$_SESSION['pseudo']:NULL; $pseudo_dest = isset($_GET['pseudo'])?$_GET['pseudo']:NULL; $return = 0; if($pseudo_exp && $pseudo_dest){ $sql = "UPDATE amis SET active=1 ,date_confirmation=NOW WHERE pseudo_exp = :get_pseudo AND pseudo_dest = :session_pseudo // je place les params dans une variable avant de l'utiliser : $params = array(':session_pseudo' => $pseudo_exp , ':get_pseudo' => $pseudo_dest); // le temps des tests echo "<br>params : <br>"; print_r($params); try{ $query = $bdd->prepare($sql); $query ->execute($params); $return = 1; }catch(Exception $e) { echo "<br>".$e->getMessage()."<br>"; echo "<br>params : <br>"; print_r($params); } } return $return; }
Si tu tapes cette requête directement dans ta BDD
Et qu'ensuite tu vas regarder dans ta BDD ... active est toujours à 0 ?
UPDATE amis SET active=1 ,date_confirmation=NOW() WHERE pseudo_exp = 'jean' AND pseudo_dest = 'xzak47'
Et qu'ensuite tu vas regarder dans ta BDD ... active est toujours à 0 ?
ok.
remet le active à 0.
Maintenant on va retester avec la page PHP.
remet le active à 0.
Maintenant on va retester avec la page PHP.
<?php //la function qui va accepter l'invitation function accepter_invitation() { global $bdd; //récupération des variables PROPREMENT ! $pseudo_exp = isset($_SESSION['pseudo'])?$_SESSION['pseudo']:NULL; $pseudo_dest = isset($_GET['pseudo'])?$_GET['pseudo']:NULL; $return = 0; if($pseudo_exp && $pseudo_dest){ $sql = "UPDATE amis SET active=1 ,date_confirmation=NOW() WHERE pseudo_exp = :session_pseudo AND pseudo_dest = :get_pseudo"; // je place les params dans une variable avant de l'utiliser : $params = array(':session_pseudo' => $pseudo_exp , ':get_pseudo' => $pseudo_dest); // le temps des tests echo "<br> Requete : <br>".$sql; echo "<br>params : <br>"; print_r($params); try{ $query = $bdd->prepare($sql); $query ->execute($params); $return = 1; }catch(Exception $e) { echo "<br>".$e->getMessage()."<br>"; echo "<br>params : <br>"; print_r($params); } } return $return; }
<?php //la function qui va accepter l'invitation function accepter_invitation() { global $bdd; //récupération des variables PROPREMENT ! $pseudo_session = isset($_SESSION['pseudo'])?$_SESSION['pseudo']:NULL; $pseudo_get = isset($_GET['pseudo'])?$_GET['pseudo']:NULL; $return = 0; if($pseudo_exp && $pseudo_dest){ $sql = "UPDATE amis SET active=1 ,date_confirmation=NOW() WHERE pseudo_exp = :get_pseudo AND pseudo_dest = :session_pseudo "; // je place les params dans une variable avant de l'utiliser : $params = array(':session_pseudo' =>$pseudo_session , ':get_pseudo' => $pseudo_get ); // le temps des tests echo "<br> Requete : <br>".$sql; echo "Je suis connecté en tant que : ".$pseudo_session; echo " Je veux refuser l'invitation de :".$pseudo_get; echo "<br>params : <br>"; print_r($params); try{ $query = $bdd->prepare($sql); $query ->execute($params); $return = 1; }catch(Exception $e) { echo "<br>".$e->getMessage()."<br>"; echo "<br>params : <br>"; print_r($params); } } return $return; }
j'ai trouvé :
J'ai :
Requete :
UPDATE amis SET active=1 ,date_confirmation=NOW() WHERE pseudo_exp = :get_pseudo AND pseudo_dest = :session_pseudo Je suis connecté en tant que : xzak47 Je veux refuser l'invitation de :jean
params :
Array ( [:session_pseudo] => xzak47 [:get_pseudo] => jean ) Invitation acceptée !
Active = 0 ... :'(
if($pseudo_session && $pseudo_get){
J'ai :
Requete :
UPDATE amis SET active=1 ,date_confirmation=NOW() WHERE pseudo_exp = :get_pseudo AND pseudo_dest = :session_pseudo Je suis connecté en tant que : xzak47 Je veux refuser l'invitation de :jean
params :
Array ( [:session_pseudo] => xzak47 [:get_pseudo] => jean ) Invitation acceptée !
Active = 0 ... :'(
Essayes ça
Cordialement,
Jordane
//la function qui va accepter l'invitation function accepter_invitation() { global $bdd; //récupération des variables PROPREMENT ! $pseudo_session = isset($_SESSION['pseudo'])?$_SESSION['pseudo']:NULL; $pseudo_get = isset($_GET['pseudo'])?$_GET['pseudo']:NULL; $return = 0; if($pseudo_session && $pseudo_get){ $sql = "UPDATE amis SET active=1 ,date_confirmation=NOW() WHERE pseudo_exp = :get_pseudo AND pseudo_dest = :session_pseudo "; // je place les params dans une variable avant de l'utiliser : $params = array(':session_pseudo' =>$pseudo_session , ':get_pseudo' => $pseudo_get ); // le temps des tests echo "<br> Requete : <br>".$sql; echo "<br>Je suis connecté en tant que : ".$pseudo_session; echo "<br> Je veux refuser l'invitation de :".$pseudo_get; echo "<br>params : <br>"; print_r($params); $etatDemande_AVANT = checkActive($pseudo_session,$pseudo_get ); echo " <br> La demande est pour l'instant :".$etatDemande_AVANT; try{ $query = $bdd->prepare($sql); $query ->execute($params); $etatDemande = checkActive($pseudo_session,$pseudo_get ); echo " <br> La demande est maintenant = ".$etatDemande; $return = $etatDemande; }catch(Exception $e) { echo "<br>".$e->getMessage()."<br>"; echo "<br>params : <br>"; print_r($params); } } return $return; } /** * Verifie l'état d'une demande */ function checkActive($pseudo_dest,$pseudo_exp ) { global $bdd; $return = -1; $sql = "SELECT active FROM amis WHERE pseudo_exp = :pseudo_exp AND pseudo_dest = :pseudo_dest "; // je place les params dans une variable avant de l'utiliser : $params = array(':pseudo_dest' =>$pseudo_dest , ':pseudo_exp' => $pseudo_exp ); try{ $query = $bdd->prepare($sql); $query ->execute($params); $result = $query->fetchall(); $return = count($result)>0 ? $result[0]['active']:-1; }catch(Exception $e) { echo "<br>".$e->getMessage()."<br>"; echo "<br>params : <br>"; print_r($params); } return $return; }
Cordialement,
Jordane
J'ai enlevé mais y a tjr le : Invitations :
Array ( [0] => Array ( [pseudo_exp] => jean [0] => jean [date_invitation] => 2015-06-18 23:01:52 [1] => 2015-06-18 23:01:52 [active] => 1 [2] => 1 [avatar] => defaut.jpg [3] => defaut.jpg ) )
Array ( [0] => Array ( [pseudo_exp] => jean [0] => jean [date_invitation] => 2015-06-18 23:01:52 [1] => 2015-06-18 23:01:52 [active] => 1 [2] => 1 [avatar] => defaut.jpg [3] => defaut.jpg ) )
<?php //la function qui va accepter l'invitation function accepter_invitation() { global $bdd; //récupération des variables PROPREMENT ! $pseudo_session = isset($_SESSION['pseudo'])?$_SESSION['pseudo']:NULL; $pseudo_get = isset($_GET['pseudo'])?$_GET['pseudo']:NULL; $return = 0; if($pseudo_session && $pseudo_get){ $sql = "UPDATE amis SET active=1 ,date_confirmation=NOW() WHERE pseudo_exp = :get_pseudo AND pseudo_dest = :session_pseudo "; // je place les params dans une variable avant de l'utiliser : $params = array(':session_pseudo' =>$pseudo_session , ':get_pseudo' => $pseudo_get ); /** * Verifie l'état d'une demande */ function checkActive($pseudo_dest,$pseudo_exp ) { global $bdd; $return = -1; $sql = "SELECT active FROM amis WHERE pseudo_exp = :pseudo_exp AND pseudo_dest = :pseudo_dest "; // je place les params dans une variable avant de l'utiliser : $params = array(':pseudo_dest' =>$pseudo_dest , ':pseudo_exp' => $pseudo_exp ); try{ $query = $bdd->prepare($sql); $query ->execute($params); $result = $query->fetchall(); $return = count($result)>0 ? $result[0]['active']:-1; }catch(Exception $e) { echo "<br>".$e->getMessage()."<br>"; echo "<br>params : <br>"; print_r($params); } return $return; }
C'est quoi ce code ????
Tu ne parviens pas à faire juste un copier coller sans sans faire d'erreurs ???
Tu as enlever trop de lignes !!!!!!
Remplaces TOUT par ça :
Penses aussi à modifier ta page ACCEPTER.PHP
Tu ne parviens pas à faire juste un copier coller sans sans faire d'erreurs ???
Tu as enlever trop de lignes !!!!!!
Remplaces TOUT par ça :
//la function qui va accepter l'invitation function accepter_invitation() { global $bdd; //récupération des variables PROPREMENT ! $pseudo_session = isset($_SESSION['pseudo'])?$_SESSION['pseudo']:NULL; $pseudo_get = isset($_GET['pseudo'])?$_GET['pseudo']:NULL; $return = 0; if($pseudo_session && $pseudo_get){ $sql = "UPDATE amis SET active=1 ,date_confirmation=NOW() WHERE pseudo_exp = :get_pseudo AND pseudo_dest = :session_pseudo "; // je place les params dans une variable avant de l'utiliser : $params = array(':session_pseudo' =>$pseudo_session , ':get_pseudo' => $pseudo_get ); try{ $query = $bdd->prepare($sql); $query ->execute($params); $etatDemande = checkActive($pseudo_session,$pseudo_get ); // echo " <br> La demande est maintenant = ".$etatDemande; $return = $etatDemande; }catch(Exception $e) { echo "<br>ERREUR ! ".$e->getMessage()."<br>"; echo "<br>params : <br>"; print_r($params); } } return $return; } /** * Verifie l'état d'une demande */ function checkActive($pseudo_dest,$pseudo_exp ) { global $bdd; $return = -1; $sql = "SELECT active FROM amis WHERE pseudo_exp = :pseudo_exp AND pseudo_dest = :pseudo_dest "; // je place les params dans une variable avant de l'utiliser : $params = array(':pseudo_dest' =>$pseudo_dest , ':pseudo_exp' => $pseudo_exp ); try{ $query = $bdd->prepare($sql); $query ->execute($params); $result = $query->fetchall(); $return = count($result)>0 ? $result[0]['active']:-1; }catch(Exception $e) { echo "<br>ERREUR ! ".$e->getMessage()."<br>"; echo "<br>params : <br>"; print_r($params); } return $return; }
Penses aussi à modifier ta page ACCEPTER.PHP
<?php $etat = accepter_invitation(); if($etat>0){ header("Location:index.php?page=profile&pseudo=".$_GET['pseudo']); }else{ echo "<br> Une erreur s'est produite ! <br> ACTIVE = ".$etat; } ?>
Merci bien ;)
avant de passer à refuser.func.php, j'aurais une question :
comment enlever ceci sur profile.php :
pseudo_exp : jean
pseudo_dest : xzak47
resultat de la requete:
Array ( )
Result :0
avant de passer à refuser.func.php, j'aurais une question :
comment enlever ceci sur profile.php :
pseudo_exp : jean
pseudo_dest : xzak47
resultat de la requete:
Array ( )
Result :0
<?php //----------------------------- //Profile.php //----------------------------- include_once('body/header.php'); include_once('body/menu.php'); $pseudo = isset($_GET['pseudo'])?$_GET['pseudo']:NULL; $arr_infos = recuperer_info_membre_choisi($pseudo); $accepter_demande = accepter_demande(); $demande_existe = demande_existe(); $verifier_expediteur = verifier_expediteur(); if(count($arr_infos)>0 && $pseudo != $_SESSION['pseudo']){ foreach($arr_infos as $R) { if($demande_existe == 0){ echo "<div class='error'> Vous n'êtes pas ami(e) avec ".$R['pseudo']."<br /> <a href='index.php?page=envoi&pseudo=".$R['pseudo']."'>Envoyer une invitation</a> </div>"; }else if( $accepter_demande == 0 && $verifier_expediteur == 1){ echo "<div class='success'>Demande envoyée <a href='index.php?page=annuler&pseudo=".$R['pseudo']."'>Annuler la demande</a></div>"; }else if($accepter_demande == 0 && $verifier_expediteur == 0){ echo "<div class='success'>Demande en cours<br /> Verifiez vos invitations </div>"; } echo"<img src='avatar/". $R['avatar']."' height='200' width='200' alt='avatar'>"; echo "<p><strong>Email : </strong><em>".$R['email']."</em></p>"; echo "<p><strong>Sexe : </strong><em>".$R['sexe']."</em></p>"; echo "<p><strong>A propos de vous : </strong><em>".$R['apropos']."</em></p>"; }//fin du foreach }else{ header("Location:index.php?page=membre"); } echo "</div>"; ?>
ATTENTION : Ne retire pas les ECHO/PRINT qui se trouveraient là pour signaler des ERREURS...
par exemple ..
Ne pas retirer ce qui se trouve dans un CATCH comme celui-ci
...ça .. il faut le laisser !
par exemple ..
Ne pas retirer ce qui se trouve dans un CATCH comme celui-ci
}catch(Exception $e) { echo "<br>ERREUR ! ".$e->getMessage()."<br>"; echo "<br>params : <br>"; print_r($params); }
...ça .. il faut le laisser !
Pour le "refuser.func.php" c'est bon ce code ? :
<?php //la function qui va refuser l'invitation function refuser_invitation() { global $bdd; //récupération des variables PROPREMENT ! $pseudo_session = isset($_SESSION['pseudo'])?$_SESSION['pseudo']:NULL; $pseudo_get = isset($_GET['pseudo'])?$_GET['pseudo']:NULL; $return = 0; if($pseudo_session && $pseudo_get){ $sql = "DELETE FROM amis WHERE pseudo_exp = :pseudo_exp AND pseudo_dest = :pseudo_dest"; // je place les params dans une variable avant de l'utiliser : $params = array(':session_pseudo' =>$pseudo_session , ':get_pseudo' => $pseudo_get ); try{ $query = $bdd->prepare($sql); $query ->execute($params); $etatDemande = checkActive($pseudo_session,$pseudo_get ); // echo " <br> La demande est maintenant = ".$etatDemande; $return = $etatDemande; }catch(Exception $e) { echo "<br>ERREUR ! ".$e->getMessage()."<br>"; echo "<br>params : <br>"; print_r($params); } } return $return; } /** * Verifie l'état d'une demande */ function checkActive($pseudo_dest,$pseudo_exp ) { global $bdd; $return = -1; $sql = "DELETE FROM amis WHERE pseudo_exp = :pseudo_exp AND pseudo_dest = :pseudo_dest"; // je place les params dans une variable avant de l'utiliser : $params = array(':pseudo_dest' =>$pseudo_dest , ':pseudo_exp' => $pseudo_exp ); try{ $query = $bdd->prepare($sql); $query ->execute($params); $result = $query->fetchall(); $return = count($result)>0 ? $result[0]['active']:-1; }catch(Exception $e) { echo "<br>ERREUR ! ".$e->getMessage()."<br>"; echo "<br>params : <br>"; print_r($params); } return $return; }
Par contre... vu qu'on en est déjà à 124 messages dans cette discussion... et vu qu'il est préférable de ne gérer qu' UN problème par discussion ... merci de clore ce sujet .. et d'en ouvrir un spécifiquement pour cet autre souci.
N'oublies pas d'y mettre :
- Le code de la page refuser.php
- Le code de ta page refuser.func.php
N'oublies pas d'y mettre :
- Le code de la page refuser.php
- Le code de ta page refuser.func.php
A remplacer par
qu'en est il pour le 2/ & 3/ svp?