未定义的索引-表单不通过javascript将值发送到php代码


undefined index - form not sending value through to php code via javascript

尝试在数据库中添加新记录时收到以下错误消息:

注意:第13行的/Applications/XAMPP/examplefiles/htdocs/insights/ManageCourse_AddSubmit.php中的未定义索引:course_titleNULL消息:SQLSTATE[23000]:违反完整性约束:1048列"course_title"不能为空

我有类似的查询,可以更新和删除表中的记录,它们运行良好,所以我不确定为什么会出现问题。

它对course_title说NULL,但在javascript中,我串行化了表单信息,所以我不确定它为什么不发送它。

course_details表有一个自动递增字段,当添加记录时,该字段会自动更新。

有人能解释一下可能是什么问题吗?

处理点击提交时发生的事情的javascript:

function addCall() {
  var data = $('#addForm').serialize();
  $.post('ManageCourses_AddSubmit.php', data, function(response){
    $("#addForm").html(response);
  }).fail(function(jqXHR, textStatus) {
    alert( "Request failed: " + textStatus );
  });
}

提交表单的模式:

<div class="modal fade" id="addModal" tabindex="-1" role="dialog" aria-labelledby="addModalLabel" aria-hidden="true">
                            <div class="modal-dialog">
                                <div class="modal-content">
                                    <div class="modal-header">
                                        <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">&times;</span></button>
                                        <h4 class="modal-title">Add New Record: </h4>
                                    </div>
                                    <div class="modal-body">
                                        <form id="addForm" class="addForm">
                                            <div class="form-group">
                                                <label for="course_code" class="pull-left" class="control-label">Course Code:</label>
                                                <input type="text" class="form-control" id="ourse_code_id" name="code[]" readonly value ="NULL">
                                            </div>
                                            <div class="form-group">
                                                <label for="course_name" class="pull-left" class="control-label">Course Title:</label>
                                                <input type="text" class="form-control" placeholder="Enter Course Title" id="course_name_id" name="title[]">
                                            </div>
                                        </form>
                                    </div>
                                    <div class="modal-footer">
                                        <div class="btn-toolbar">
                                            <button type="button" class="btn btn-primary" id="add_row" name="add_row">Add New Record <span class="glyphicon glyphicon-plus"></button>
                                            <button type="button" class="btn btn-default" class="pull-right" data-dismiss="modal">Close</button>
                                            <button type="button" class="btn btn-success" class="pull-right" onclick="addCall();">Submit <span class="glyphicon glyphicon-saved"></button>
                                        </div>
                                    </div>
                                </div>
                            </div>
                        </div>

最后是php文件:

<?php
include "db_conx.php";
    try
    {
        $db_conx = new PDO("mysql:host=$mysql_hostname;dbname=$mysql_dbname", $mysql_username, $mysql_password);
        $db_conx->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
        $sql = $db_conx->prepare("INSERT INTO `insights`.`course_details` (`course_code`, `course_title`) VALUES (:course_code, :course_title)");
        $course_title = $_POST['course_title'];
        $course_code = $_POST['course_code'];
        echo var_dump($course_title)."<br>";
        echo var_dump($course_code)."<br>";
        $sql->bindParam(':course_title', $course_title, PDO::PARAM_STR);
        $sql->bindParam(':course_code', $course_code, PDO::PARAM_STR);

        /*** execute the prepared statement ***/
        $sql->execute();
        /*** success message ***/

        $message = "<p class='text-success'> Record Successfully Added <span class='glyphicon glyphicon-ok'/></p>";
    } 
    catch(Exception $e)
    {
        $message = 'Message: ' .$e->getMessage();
    }

die($message);
?>

我注意到,当我使用反勾号(:course_title)时,它会很好地添加记录,但添加的值是:course_title

非常感谢

我认为这是一个命名错误。

在您的表单中,您有以下输入字段:

<label for="course_name" class="pull-left" class="control-label">Course Title:</label>
<input type="text" class="form-control" placeholder="Enter Course Title" id="course_name_id" name="title[]">

在这里你称之为course_name_id。然后在PHP脚本中,您尝试获取以下变量:

$course_title = $_POST['course_title'];
$course_code = $_POST['course_code'];

你把它叫做course_title

我建议你尽量清理所有使用过的名字。如果表字段被称为course_title,那么为表单和PHP控制器使用这个名称。

或者,一种更优雅的方法是,尝试将所有名称外包到一些XML配置文件中,这样您的控制器总是基于配置文件执行相同的工作:-)