sql 命令成功后刷新页面
Refreshing page upon successful sql command
我正在编写一个脚本,负责在成功更新后刷新页面。我正在使用 GET 方法来传递信息。我有一个名为 "read" 的按钮,单击该按钮将更新我的数据库并负责刷新页面。目前我正在使用这个函数创建我的 table:
function fetch_message($patient_ssn, $physician_ssn) {
global $conn, $key, $iv;
//Create query to fetch data
$query = "SELECT message_ID, message_body, date_message, time_message, read_message FROM message WHERE patient_SSN='$patient_ssn' AND physician_SSN='$physician_ssn'";
$result = mysqli_query($conn, $query);
while($row = mysqli_fetch_row($result)) {
//Enter table data here
if($row[4] == 0) {
echo '<tr class="table-danger">';
} elseif($row[4] == 1) {
echo '<tr class="table-success">';
}
echo "<td>$row[0]</td>";
$decrypted_message = decrypt_text($row[1], $key, $iv);
echo "<td>$decrypted_message</td>";
echo "<td>$row[2]</td>";
echo "<td>$row[3]</td>";
//Checkbox setup
if($row[4] == 0) {
echo "<td><input type='submit' name='read' value='Confirm $row[0]'</td>";
} elseif($row[4] == 1) {
echo "<td><lable>Confirmed</lable></td>";
}
echo '</tr>';
}
echo '<tr>';
echo '<th class="text-center" colspan="2" scope="row"><input type="submit" value="Update" name="update"</th>';
echo '</tr>';
}
这个函数调用我的更新:
function update_check($message_id, $patient_ssn, $physician_ssn) {
global $conn;
$query = "UPDATE message SET read_message='1' WHERE message_ID='$message_id' AND patient_SSN='$patient_ssn' AND physician_SSN='$physician_ssn'";
$result = mysqli_query($conn, $query);
if($result) {
echo "success";
}
}
我遇到的问题是单击按钮后,我希望它更新 table 并将页面刷新回 messaging.php。这就是我尝试重定向的方式
fetch_message($_SESSION['ssn'], $_SESSION['phy_ssn']);
//Update button has been clicked
if(isset($_GET['read'])) {
$message_id =explode(' ' , $_GET['read']);
update_check($message_id[1], $_SESSION['ssn'], $_SESSION['phy_ssn']);
echo "<meta http-equiv='refresh' content='0' URL='messaging.php'>";
}
(我也尝试过使用 header("Location: messaging.php"); 但我收到一条错误消息:
header cannot be modified
可能是因为我在脚本的顶部使用了 session_start();
。使用 meta 标记它可以工作,但它开始不间断地快速刷新。
url 看起来像这样:
http://localhost/455Project/messaging.php?read=Confirm+2
我很困惑实施这个的正确过程是什么。
我该如何解决这个问题?
尝试使用这种PHP方法。 header("refresh: 3");
您可以通过使用输出缓冲区来避免 headers 出现问题。只需在 session_start()
.
之后添加 ob_start()
顺便说一句。尝试使用准备好的 sql 语句。它更安全。
我正在编写一个脚本,负责在成功更新后刷新页面。我正在使用 GET 方法来传递信息。我有一个名为 "read" 的按钮,单击该按钮将更新我的数据库并负责刷新页面。目前我正在使用这个函数创建我的 table:
function fetch_message($patient_ssn, $physician_ssn) {
global $conn, $key, $iv;
//Create query to fetch data
$query = "SELECT message_ID, message_body, date_message, time_message, read_message FROM message WHERE patient_SSN='$patient_ssn' AND physician_SSN='$physician_ssn'";
$result = mysqli_query($conn, $query);
while($row = mysqli_fetch_row($result)) {
//Enter table data here
if($row[4] == 0) {
echo '<tr class="table-danger">';
} elseif($row[4] == 1) {
echo '<tr class="table-success">';
}
echo "<td>$row[0]</td>";
$decrypted_message = decrypt_text($row[1], $key, $iv);
echo "<td>$decrypted_message</td>";
echo "<td>$row[2]</td>";
echo "<td>$row[3]</td>";
//Checkbox setup
if($row[4] == 0) {
echo "<td><input type='submit' name='read' value='Confirm $row[0]'</td>";
} elseif($row[4] == 1) {
echo "<td><lable>Confirmed</lable></td>";
}
echo '</tr>';
}
echo '<tr>';
echo '<th class="text-center" colspan="2" scope="row"><input type="submit" value="Update" name="update"</th>';
echo '</tr>';
}
这个函数调用我的更新:
function update_check($message_id, $patient_ssn, $physician_ssn) {
global $conn;
$query = "UPDATE message SET read_message='1' WHERE message_ID='$message_id' AND patient_SSN='$patient_ssn' AND physician_SSN='$physician_ssn'";
$result = mysqli_query($conn, $query);
if($result) {
echo "success";
}
}
我遇到的问题是单击按钮后,我希望它更新 table 并将页面刷新回 messaging.php。这就是我尝试重定向的方式
fetch_message($_SESSION['ssn'], $_SESSION['phy_ssn']);
//Update button has been clicked
if(isset($_GET['read'])) {
$message_id =explode(' ' , $_GET['read']);
update_check($message_id[1], $_SESSION['ssn'], $_SESSION['phy_ssn']);
echo "<meta http-equiv='refresh' content='0' URL='messaging.php'>";
}
(我也尝试过使用 header("Location: messaging.php"); 但我收到一条错误消息:
header cannot be modified
可能是因为我在脚本的顶部使用了 session_start();
。使用 meta 标记它可以工作,但它开始不间断地快速刷新。
url 看起来像这样:
http://localhost/455Project/messaging.php?read=Confirm+2
我很困惑实施这个的正确过程是什么。 我该如何解决这个问题?
尝试使用这种PHP方法。 header("refresh: 3");
您可以通过使用输出缓冲区来避免 headers 出现问题。只需在 session_start()
.
ob_start()
顺便说一句。尝试使用准备好的 sql 语句。它更安全。