bonjour!
j'ai un probleme bizard!
Quand je vais sur le t'chat ma SESSION est automatiquement deconnecté!
si j'enleve le session_start(); du deuxieme script, il n ya plus de deconexion mais ma requete marche plus vu que je me sert de $_SESSION['pseudo'];..
<?php
$reponse = mysql_query("SELECT expediteur, message, timestamp FROM chat WHERE destinataire='".$_SESSION['pseudo']."'OR expediteur='".$_SESSION['pseudo']."'");
while ($donnees = mysql_fetch_array($reponse) )?>
j'utilise des session_start() pratiquement sur toute mes pages, ils fonctionnent bien , aucun problème.
la deconnection s'effectue juste quand je me rend sur la page de chat en même temps que le rafraichisement du deuxieme script que j'ai donnée.
si vous faire le teste par vous même:
http://www.uncupidon.com
voici un compte test:
pseudo = test
password= azerty
une fois connecter , cliquer sur une des photos de la premiere page et cliquer sur chat!
normalement vous allez etre deconectée!
bon j'espere que vous allez pouvoir m'aider!
voici les 2 script qui rentre en jeu:
<?php
session_start();
$_SESSION['pseudo'];
$_SESSION['logged'];
?>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html><head>
<title>Chat</title>
<script type="text/javascript">
function plop()
{
var xhr_object = null;
if(window.XMLHttpRequest) // Firefox
xhr_object = new XMLHttpRequest();
else
{
if(window.ActiveXObject) // Internet Explorer
xhr_object = new ActiveXObject("Microsoft.XMLHTTP");
else // XMLHttpRequest non supporté par le navigateur
{
alert("Votre navigateur ne supporte pas les objets XMLHTTPRequest...");
return;
}
}
var method = "POST";
var filename = "reponse.php";
var requete = "message=<?php echo'.$retour.'?>";
xhr_object.onreadystatechange = function()
{
if(xhr_object.readyState == 4)
{
var reponse = xhr_object.responseText;
document.getElementById("content").innerHTML = reponse;
}
}
xhr_object.open(method, filename, true);
xhr_object.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
xhr_object.send(requete);
}
</script>
<script>
function refresh()
{
plop();
setTimeout("refresh()", 5000);
}
</script>
</head>
<style type="text/css">
#chatcomplet
{
width:400px;
height:400px;
background-repeat: no-repeat;
border: 1px solid black;
}
#content
{
position : absolute ;
width:400px;
height:300px;
background-color: red;
color : yellow;
overflow : scroll ;
border: 1px solid green;
}
#message
{
background-color: green;
background-attachment: fixed;
width:400px;
height:100px;
border: 1px solid green;
padding: 1px;
padding-top: 300px;
}
</style>
$cnx=mysql_connect("......", "..........", "..........") or die("Pb connexion au serveur".mysql_error());
$db=mysql_select_db("..........") or die("Pb selection base".mysql_error());
if ( isset( $_POST['message'] ) && !is_null( $_POST['message'] ) )
{
$message = mysql_real_escape_string( htmlspecialchars( $_POST['message'] ) );
$timestamp = time();
$expediteur = $_SESSION['pseudo'];
$destinataire = $_GET['pseudo'];
mysql_query( "INSERT INTO chat VALUES('', '$expediteur', '$destinataire', '$message', '$timestamp', '')" ); // et tu ne stockes pas le résultat dans une variable ?
}
$destinataire = $_GET['pseudo'];
?>
<body onLoad="plop()">
<div id="content"></div>
<div id="chatcomplet">
<form action="<?php echo'chat.php?pseudo='.$destinataire.''?>" method="post"/>
<div id="message">
<p>Message : <input type="text" name="message" size="30"/><br />
<input type="submit" value="Envoyer" />
</p>
</div>
</div>
<?php
mysql_close();
?>
</form>
<script>
refresh();
</script>
</body></html>
et voici le deuxieme, il sert a afficher les message dans le <div id="content">,
il se rafraichie toute les 5 seconde:
<?php
session_start();
$cnx=mysql_connect("...........", "...........", "...........") or die("Pb connexion au serveur".mysql_error());
$db=mysql_select_db(".............") or die("Pb selection base".mysql_error());
$reponse = mysql_query("SELECT expediteur, message, timestamp FROM chat WHERE destinataire='".$_SESSION['pseudo']."'OR expediteur='".$_SESSION['pseudo']."'");
while ($donnees = mysql_fetch_array($reponse) )
{
$date = date('d/m/Y à Hhi', $donnees['timestamp']);
$message = $donnees['message'];
$expediteur = $donnees['expediteur'];
$pseudo= $_GET['pseudo'];
echo '<p><strong> '.$expediteur.' </strong> le '.$date.' : '.$message.' </p>';
}
mysql_close(); // Déconnexion de MySQL
?>