php评论部分在我的网站上

时间:2013-07-24 14:59:45

标签: php

我遇到第4,5,6行的问题,一切正常,数据被发送到数据库以及输出结果但是我在加载页面时收到此消息。

Undefined index: name in C:\xampp\htdocs\xampp\site\comment.php on line 4

Notice: Undefined index: comment in C:\xampp\htdocs\xampp\site\comment.php on line 5

Notice: Undefined index: submit in C:\xampp\htdocs\xampp\site\comment.php on line 6

再次感谢,任何帮助将不胜感激:) 这是代码,非常感谢能提前帮助我的人

<?php
mysql_connect("localhost","root","");
mysql_select_db("commentbox");

$name= $_POST["name"];
$comment= $_POST["comment"];
$submit= $_POST["submit"];

$dbLink = mysql_connect("localhost", "root", "Broadband74");
    mysql_query("SET character_set_client=utf8", $dbLink);
    mysql_query("SET character_set_connection=utf8", $dbLink);

if($submit)
{
    if($name&&$comment)
    {
        mysql_query("INSERT INTO commenttable (name,comment) VALUES ('$name','$comment') ");
    }
    else
    {
        echo "please fill out all fields";
    }
}
?>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Comment box</title>
</head>

<body>
<center>
<form action="comment.php" method="POST">
<table>
<tr><td>Name: <br><input type="text" name="name"/></td></tr>
<tr><td colspan="2">Comment: </td></tr>
<tr><td colspan="5"><textarea name="comment" rows="10" cols="50"></textarea></td></tr>
<tr><td colspan="2"><input type="submit" name="submit" value="Comment"></td></tr>
</table>
</form>
<?php
$dbLink = mysql_connect("localhost", "root", "");
    mysql_query("SET character_set_results=utf8", $dbLink);
    mb_language('uni');
    mb_internal_encoding('UTF-8');

$getquery=mysql_query("SELECT * FROM commenttable ORDER BY id DESC");
while($rows=mysql_fetch_assoc($getquery))
{
    $id=$rows["id"];
    $name=$rows["name"];
    $comment=$rows["comment"];
    echo $name . '<br/>' . '<br/>' . $comment . '<br/>' . '<br/>' . '<hr size="1"/>'
;}
?>

</body>
</html>

5 个答案:

答案 0 :(得分:0)

<?php
mysql_connect("localhost","root","");
mysql_select_db("commentbox");

if(isset($_POST["name"]){
$name= $_POST["name"];
}
if(isset($_POST["comment"]){
$comment= $_POST["comment"];
}
if(isset($_POST["submit"]){
$submit= $_POST["submit"];
}

$dbLink = mysql_connect("localhost", "root", "Broadband74");
    mysql_query("SET character_set_client=utf8", $dbLink);
    mysql_query("SET character_set_connection=utf8", $dbLink);

if($submit)
{
if($name&&$comment)
{
mysql_query("INSERT INTO commenttable (name,comment) VALUES ('$name','$comment') ");
}
else
{
echo "please fill out all fields";
}
}
?>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Comment box</title>
</head>

<body>
<center>
<form action="comment.php" method="POST">
<table>
<tr><td>Name: <br><input type="text" name="name"/></td></tr>
<tr><td colspan="2">Comment: </td></tr>
<tr><td colspan="5"><textarea name="comment" rows="10" cols="50"></textarea></td></tr>
<tr><td colspan="2"><input type="submit" name="submit" value="Comment"></td></tr>
</table>
</form>
<?php
$dbLink = mysql_connect("localhost", "root", "");
    mysql_query("SET character_set_results=utf8", $dbLink);
    mb_language('uni');
    mb_internal_encoding('UTF-8');

$getquery=mysql_query("SELECT * FROM commenttable ORDER BY id DESC");
while($rows=mysql_fetch_assoc($getquery))
{
$id=$rows["id"];
$name=$rows["name"];
$comment=$rows["comment"];
echo $name . '<br/>' . '<br/>' . $comment . '<br/>' . '<br/>' . '<hr size="1"/>'
;}
?>

</body>
</html>

答案 1 :(得分:0)

首次加载页面时,尚未绑定到请求的POST数据,因此在提交表单之前它已失败。您可以检查是否使用isset()设置了值,您可以明确地处理错误:

http://php.net/manual/en/language.exceptions.php

或者,您可以将表单和代码放在不同的页面上进行处理。

答案 2 :(得分:0)

您需要使用具有mysqli_PDO功能的参数,但是:

<?php
mysql_connect("localhost","root","");
mysql_select_db("commentbox");

$dbLink = mysql_connect("localhost", "root", "Broadband74");
    mysql_query("SET character_set_client=utf8", $dbLink);
    mysql_query("SET character_set_connection=utf8", $dbLink);

if($_POST["submit"])
{
    if( (isset($_POST["name"]) && !empty($_POST["name"])) &&
        (isset($_POST["comment"]) && !empty($_POST["name"])) )
    {
        $name= $_POST["name"];
        $comment= $_POST["comment"];
        mysql_query("INSERT INTO commenttable (name,comment) VALUES ('$name','$comment') ");
    }
    else
    {
        echo "please fill out all fields";
    }
}

答案 3 :(得分:0)

您必须先检查您的表单是否已提交:

if(isset($_POST['submit']))
{    
    mysql_connect("localhost","root","");
    mysql_select_db("commentbox");

    $name= $_POST["name"];
    $comment= $_POST["comment"];
    $submit= $_POST["submit"];

    $dbLink = mysql_connect("localhost", "root", "Broadband74");
    mysql_query("SET character_set_client=utf8", $dbLink);
    mysql_query("SET character_set_connection=utf8", $dbLink);

    if($name&&$comment)
    {
        mysql_query("INSERT INTO commenttable (name,comment) VALUES ('$name','$comment') ");
    }
    else
    {
        echo "please fill out all fields";
    }
}

答案 4 :(得分:0)

每次加载页面时都会执行PHP代码。在第一次加载时,未给出表单输入,并且未设置这些值。但是你的脚本试图使用$_POST['field'],因为PHP不知道这些字段,它只会引发Undefined Index错误。

这个问题的解决方案实际上非常简单。使用isset()

<?php

if(isset($_POST['submit']) { //checking if form was submitted

mysql_connect("localhost","root","");
mysql_select_db("commentbox");

$name = isset($_POST['name']) ? $_POST['name'] : null; 
$comment= isset($_POST['comment']) ? $_POST['comment'] : null; 
$submit= isset($_POST["submit"]) ? $_POST["submit"] : null;

$dbLink = mysql_connect("localhost", "root", "Broadband74");
    mysql_query("SET character_set_client=utf8", $dbLink);
    mysql_query("SET character_set_connection=utf8", $dbLink);

if($submit)
{
    if($name&&$comment)
    {
        mysql_query("INSERT INTO commenttable (name,comment) VALUES ('$name','$comment') ");
    }
    else
    {
        echo "please fill out all fields";
    }
}
?>