1

那里!我想进行数据库搜索并以预先填充的 HTML 表单将结果显示给用户。

我找到了代码中不起作用的确切部分,但我不明白为什么服务器没有选择 PHP。我正在使用 UwAMP。

为了说明这里的问题是我需要帮助的一小段代码:

<form id="st_reg" action="" method="POST">
        Student Number:
        <input type="number" name="s_num" min="1000000" max="3000000" > </br>
        <input type="Submit" value="Search">
    </form>
    <?php 
        if($_SERVER['REQUEST_METHOD'] == "POST"){
            if(empty($_POST['s_num'])){
                $errors[] = "You forgot to enter the Student No!";
            }
            else{
                $st_no = trim($_POST['s_num']);
            }
            if(empty($errors)){
                //Open database connection
                require('../../connect_to_database/mysql_connect.php');
                //Check if the student is already in the database
                $query = "SELECT * FROM student WHERE student_no = $st_no";
                //Run the query
                $result = mysqli_query($db_connection,$query);
                if(!$result){
                    echo "The student does not exist!";
                    echo"Please <a href='index.html'>go back</a> and choose another action!";
                }
                elseif($result){
                    echo "<h2>Student Details:</h2>";
                    while($row = mysqli_fetch_array($result)){
                        echo '<form id="st_reg" action="" method="POST">
                                <label>Student Number:</label>
                                    <input type="number" name = "st_number" min="1000000" max="3000000" value="<?php if(isset(\$row[\'student_no\'])) echo \$row[\'student_no\']; ?> ">

并且 VALUE ATTRIBUTE 中的 PHP 代码实际上没有执行。不要担心 GLOBAL php 标签没有被关闭,因为它们在文件中(我不是那个转储)。

请注意,所有这些代码都在一个带有 HTML 代码的.php文件中。这只是表单提交后的处理部分。我通过使用单引号来回显节省了我的时间,并在需要数据库访问的过程中转义了单引号。我尝试用大括号括住变量,用双引号回显其中的双引号,但这些尝试都没有成功。这很奇怪,因为我可以在此上下文之外完美地回显 $row['student_no'] 并且运行良好。

我也在这个网站上查看了类似的问题。他们很接近,但没有一个人接近这种情况。我愿意接受任何建议,并且比该解决方案更好。

4

2 回答 2

2
echo '<form id="st_reg" action="" method="POST">
<label>Student Number:</label>
<input type="number" name = "st_number" min="1000000" max="3000000" value="<?php if(isset(\$row[\'student_no\'])) echo \$row[\'student_no\']; ?> ">

应该是这样的:

echo '<form id="st_reg" action="" method="POST">
<label>Student Number:</label>
<input type="number" name = "st_number" min="1000000" max="3000000" value="' . (isset($row['student_no']) ? $row['student_no'] : '') . '">
CONTINUATION OF STRING...
于 2017-07-18T21:16:10.163 回答
0

以下将做你想要的。

value="<?= (isset($row["student_no"]) ? $row["student_no"] : "") ?>"

当您已经在 PHP 块中时,您无需担心所有转义。

于 2017-07-18T21:19:43.450 回答