2014-01-10 106 views
0

app.php从其他页面获取帖子值。并且该值用于查询目的。该帖子值用于编辑app.php中的多个值。我再次发布多个值到edit.php来更新app.php中显示的记录。我想要的是,当我使用<meta http-equiv="refresh" content="0;app.php" /><script type="text/javascript">window.history.go(-1);</script>重新进入app.php时,app.php中的值应该从edit.php中获取新值或更新值。我不擅长使用会话。请帮助?如何更改会话的值

app.php

$mysqli = new mysqli("localhost", "root", "", "app"); 
ob_start(); 
session_start() 

<form name="myform" method="post" action="edit.php"/> 
if (isset($_POST['submit'])) { 

    //unset the session value 
    $_SESSION['content'] = ''; 

    $drop  = $_POST['drop_1']; 
    $tier_two = $_POST['tier_two']; 

    $where = "WHERE a.app_cn='$drop' AND a.app_plan_no='$tier_two'"; 

    $result1 = $mysqli->query(" query "); 

<table> 
while ($row = $result1->fetch_assoc()) { 
<td><input name="checkbox[]" type="checkbox" id="checkbox[]" value="' . $row['id'] . '"'.($row['pr'] == ""?"disabled ":"").' style="cursor:pointer;" class="checkbox"></td> 
} 
</table> 

$sPageContent  = ob_get_clean(); 
    $_SESSION['content'] = $sPageContent; 
     echo $_SESSION['content']; 
} else { 
    if (isset($_SESSION['content'])) { 
     echo $_SESSION['content']; 
    } 
} 
</form> 

Edit.php

<?php 
$mysqli = new mysqli("localhost", "root", "", "app"); 
if (isset($_POST['submit'])) { 
$counter=$_POST['counter']; 
$pr=$_POST['pr']; 
$pr_qty=$_POST['pr_qty']; 
$N = count($counter); 
for($i=0; $i < $N; $i++) 
{ 
    $result = $mysqli->query("UPDATE purchase_request SET pr='$pr[$i]', total_quantity='$pr_qty[$i]' where counter='$counter[$i]'"); 
} 
    echo'<meta http-equiv="refresh" content="0;app.php" />'; 
} 

?> 

<form class="form-horizontal" action="" method="post">  
<?php 
$id=$_POST['checkbox']; 
$N = count($id); 
for($i=0; $i < $N; $i++) 
{ 
    $result1 = $mysqli->query(" 
SELECT a.item_name, a.item_description, a.counter, b.counter, b.pr, b.total_quantity 
FROM app a 
LEFT OUTER JOIN purchase_request b 
ON a.counter=b.counter 
WHERE a.counter='$id[$i]' 
    "); 
    while ($row = $result1->fetch_assoc()) 
     { ?> 
<input name="item_name[]" class="textbox" type="text" value="<?php echo $row['item_name'] ?>"/> 
<input name="item_description[]" class="textbox" type="text" value="<?php echo $row['item_description'] ?>"/> 
<input name="pr_qty[]" id="pr_qty[]" class="textbox tb1" type="text" value="<?php echo $row['total_quantity']; ?>" /> 
<input name="pr[]" class="textbox" type="text" value="<?php echo $row['pr'] ?>" /> 
?> 
<input name="submit" type="submit" id="sbtBtn" value="Update"> 
</form> 
+0

@弗雷德-II-很好的答案,但我不明白:(我在使用会话 – user3097736

+0

@弗雷德-II很难 - 好吧,给我一些提示,我怎么才能得到edit.php的价值,所以我可以在app.php中更改会话 – user3097736

+0

@ Fred-ii-我在地狱里:( – user3097736

回答

0

使用,如果你正在使用javascript返回它可以保持现有的数据页,而不是<meta http-equiv="refresh" content="0;app.php" />

header('Location: app.php')。这是因为我们的浏览器有缓存。

您可以使用 <META HTTP-EQUIV="CACHE-CONTROL" CONTENT="NO-CACHE"><META HTTP-EQUIV="EXPIRES" CONTENT="Mon, 22 Jul 2002 11:12:01 GMT"> 禁用缓存

+0

我试过了,但它不工作:( – user3097736