У меня есть простая контактная форма на веб-сайте с 2 текстовыми полями, 1 текстовой областью и 1 скрытым полем.
По какой-то причине все поля POST в PHP-скрипт, кроме textarea. Я делал это тысячу раз раньше, и никогда не было этой проблемы.
Вот мой HTML:
<form action="scripts/contactform.php" method="post">
<table width="0" border="0" cellspacing="3" cellpadding="5" class="gpass">
<tr>
<td>Name:</td>
<td><input name="name" type="text" maxlength="50" /></td>
</tr>
<tr>
<td>E-mail:</td>
<td><input name="email" type="text"/></td>
</tr>
<tr>
<td>Message:</td>
<td><textarea name="comment" id="comment" cols="30" rows="5"></textarea>
<input type="hidden" value=" <?php echo $_SERVER['REMOTE_ADDR'];?>" name="address" />
</td>
</tr>
<tr>
<td colspan="2" align="center"><input name="submit" type="submit" value="Submit" class="noround" id="regbut" /><input name="reset" type="reset" value="Reset" class="noround" id="regbut"/></td>
</tr>
</table>
</form>
А мой скрипт выглядит так:
$link = mysql_connect(DB_HOST, DB_USER, DB_PASSWORD);
if(!$link)
{
die('Failed to connect to server: ' . mysql_error());
}
$db = mysql_select_db(DB_DATABASE);
if(!$db)
{
die("Unable to select database");
}
$name = mysql_real_escape_string($_POST['name']);
$email = mysql_real_escape_string($_POST['email']);
$comment = mysql_real_escape_string($_POST['comment']);
$ipaddress = mysql_real_escape_string($_POST['address']);
У меня есть несколько вещей для обработки данных под этим, но это не имеет значения, поскольку переменная $comment
не определена. Я просмотрел весь сценарий и не нашел конфликтующих имен переменных.
Я совершенно озадачен тем, почему это происходит. Я уже несколько раз успешно обрабатывал textarea
на своем сайте, так что это действительно сбивает с толку.