mysql — редактирование данных в выпуске db

Я собираюсь быть кратким и простым. Я пишу действительно простой код на php, который добавляет контент в mysql db, и у меня возникла проблема с редактированием. Это моя форма:

if($idExists)
{
Print '
<form action="editIt.php" method="POST">
<div name="id"> '. $id . '</div>
Enter new detail: <input type="text" name="details"/><br/>
public post? <input type="checkbox" name="public[]" value="yes"/><br/>
<input type="submit" value="Update List"/>
</form>
';
}

И это мой editIt.php

//session start and stuff
if(filter_input(INPUT_SERVER, 'REQUEST_METHOD', FILTER_SANITIZE_STRING) == "POST")
{
echo "<script type='text/javascript'>alert('EDITIT!');</script>";
mysql_connect("localhost", "root", "") or die(mysql_error());
mysql_select_db("WebSiteDB") or die ("Cannot connect to database");
$id = $_POST['id'];
$details = mysql_real_escape_string($_POST['details']);
$time = strftime("%X");
$date = strftime("%B %d, %Y");
$isPublic = 'no';

foreach($_POST['public'] as $eachCheck)
{
if($eachCheck != NULL)
$isPublic = "yes";
}

mysql_query("UPDATE list SET details='$details', dateEdited='$date', timeEdited= '$time', public='$isPublic' WHERE id='$id'");
header("location: home.php");
}

Я действительно не могу найти проблему с этим кодом (что не очень странно, я новичок в веб-вещах), и все же он просто идет в home.php и не изменяет данные в БД. Пожалуйста, помогите мне прыгнуть на этот выступ, чтобы я мог продолжать свою жизнь.

2

Решение

Я думаю, проблема в этой линии $id = $_POST['id'];, При отправке формы значение поля ввода будет отправлено только, а не DIV значение.

Поэтому, пожалуйста, измените с:

if($idExists)
{
Print '
<form action="editIt.php" method="POST">
<div name="id"> '. $id . '</div>
Enter new detail: <input type="text" name="details"/><br/>
public post? <input type="checkbox" name="public[]" value="yes"/><br/>
<input type="submit" value="Update List"/>
</form>
';
}

Кому:

if($idExists)
{
Print '
<form action="editIt.php" method="POST">
<input type="hidden" name="id" value="' . $id . '">
Enter new detail: <input type="text" name="details"/><br/>
public post? <input type="checkbox" name="public[]" value="yes"/><br/>
<input type="submit" value="Update List"/>
</form>
';
}
2

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]