语法错误、意外T_ENCAPSED_AND_WHITESPACE、预期T_STRING或T_VARIABLE或T_NUM_STRING

2022-08-30 17:20:17

我已经盯着这个代码几个小时了,我无法弄清楚我的错误在哪里。我知道这个语法错误通常是由于一些缺失或不合时宜的大括号或单/双引号的一些问题而出现的,我不确定我的代码中是否有一个。我现在只是试图修复我的语法,这样我就可以让代码完全编译。任何帮助将不胜感激。这是我的代码:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en"> 
<head> 
<title>Add to and Read from the Database</title>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1" />
</head> 
<body>

<?php
function print_form() {
echo <<<END
         <form action="$_SERVER[PHP_SELF]" method="post">

    <h3>Please put your comments below.</h3>

<input type="hidden" name="stage" value="process" >
<p>Name:</p>
<input type="text" size="30" name="WholeName" />
<p>Comment:</p>
<input type="text" size="200" name="Comment" />

<input type ="submit"  value ="Submit" >
</form>
END;    

    }
function process_form() {

print "<p>adding comment...</p>";

$Name = $_POST['WholeName'];
$Comment = $_POST['Comment'];

    if( preg_match("^[a-zA-Z]+$", $Name)) {
        if( preg_match("^[a-zA-Z0-9]_\-\'[.?!]+$", $Comment)) {
            $sql = "insert into comments1 values ( 
           '$Name', 
           '$Comment')";
           $result = mysql_query($sql) or die("Mysql query failed");
      } else {
        print "invalid name";
        }
  } else {
print "invalid characters";
 }

}

$db = mysql_connect("", "", "");
if (!$db) {
   print "Error - Could not connect to mysql";
   exit;
}  

$er = mysql_select_db("");
if (!$er) {
  print "Error - Could not connect to comments1 database";
  exit;
}

if (isset($_POST['stage']) && ('process' == $_POST['stage'])) {
   process_form();
} else {
    print_form();
}

?>

</body>
</html>

答案 1

我偶然发现了这个问题,因为我有同样的错误。我的是由于一个稍微不同的问题,由于我自己解决了它,我认为在这里分享是有用的。有问题的原始代码:

$comment = "$_POST['comment']";

由于括起来的双引号,索引未正确取消引用,从而导致赋值错误。在我的情况下,我选择像这样修复它:

$comment = "$_POST[comment]";

但是删除任何一对引号都有效;我想这是一个风格问题:)


答案 2

你的问题是你没有正确地关闭你的HEREDOC。包含的行之后不得包含任何空格END;


推荐