Tamam benim kod $ _GET ['pid'] kullanarak sayfa id kapmak ve kontrol ve $ _SESSION ['sayfa'] eşit olup olmadığını görmek gerekir. Bu $ _SESSION ['sayfa'] yok değilse $ _SESSION ['sayfa'] tutmak ise.
Ben kullanarak başka bir sayfadan işlevini çağırdığınızda yeniden Ama nedense bir) $ _SESSION ['sayfa'] (dahil başka bir sayfadan farklı bir değere sahiptir? Ne bu soruna neden olduğunu ve bunu nasıl düzeltebilirim?
İşte benim unset $ _SESSION ['sayfa'] kodudur.
<?php
ob_start();
session_start();
if(isset($_GET['pid']) && is_numeric($_GET['pid'])) {
if(isset($_SESSION['page']) && $_SESSION['page'] !== $_GET['pid']){
unset($_SESSION['page']);
}
$page = mysqli_real_escape_string($mysqli, htmlentities(strip_tags($_GET['pid'])));
$_SESSION['page'] = $page;
}
ob_flush();
?>
Ben başka bir komut dosyası bu fonksiyonu çağırmak
<?php
ob_start();
session_start();
function getRatingText(){
$dbc = mysqli_connect("localhost", "db", "pass", "members");
$sql1 = "SELECT COUNT(ab_g.u_ab_id) FROM ab_g INNER JOIN u ON ab_g.user_id = u.user_id WHERE u_ab_id = '" . $_SESSION['page'] . "' AND u.active IS NULL AND u.deletion = 0";
$result = mysqli_query($dbc,$sql1);
if (!mysqli_query($dbc, $sql1)) {
trigger_error(mysqli_error($dbc));
return;
} else {
while($row = mysqli_fetch_array($result)) {
$tr[] = $row[0];
}
}
if(isset($tr) && count($tr) != 0){ $rat = array_sum($tr); }
$sql2 = "SELECT g.rate_points FROM g INNER JOIN ab_g ON g.id = ab_g.rate_id INNER JOIN u ON ab_g.user_id = u.user_id WHERE ab_g.u_ab_id = '" . $_SESSION['page'] . "' AND u.active IS NULL AND u.deletion = 0";
$result = mysqli_query($dbc, $sql2);
if(!mysqli_query($dbc, $sql2)) {
trigger_error(mysqli_error($dbc));
return;
} else {
while($row = mysqli_fetch_array($result)) {
$trp[] = $row[0];
}
}
if(isset($trp) && count($trp) != 0){ $tot = array_sum($trp); }
if (!empty($tot) && !empty($rat)){
$avg = round($tot / $rat, 1);
$percent = round(($avg / 5) * 100, 1);
$votes = $rat;
if($rat == 1){
echo $avg . "/5 (" . $votes . " rating casted)";
} else {
echo $avg . "/5 (" . $votes . " casted)";
}
if($avg <= 5){ $rate = '5 star'; }
if($avg <= 4){ $rate = '4 star'; }
if($avg <= 3){ $rate = '3 star'; }
if($avg <= 2){ $rate = '2 star'; }
if($avg <= 1){ $rate = '1 star'; }
echo $rate;
} else {
echo 'not rating';
}
return TRUE;
}
ob_flush();
?>
I solved this problem by placing the session_write_close(); inside the function script at the bottom. before ob_flush().