0

我有一个发布到 php 处理程序的表单,它将表单中的数据保存到数据库中。我认为保存功能不是问题。我认为这是$_POST合并表单数据的问题。当我查看 sql 表时,数据在那里,但所有值都出现在一列中,因此变量从表单中正确传递。

这是我的代码:

$name = isset($_POST['name']) ? $_POST['name'] : '';
$email = isset($_POST['email']) ? $_POST['email'] : '';
$com_dis = isset($_POST['comment']) ? $_POST['comment'] : '';
$id = isset($_POST['id']) ? $_POST['id'] : '';

$lowercase = strtolower($email);
$image = md5( $lowercase );

try{
    $conn = new PDO( DB_DSN, DB_USERNAME, DB_PASSWORD );
    $sql = 'INSERT INTO comments ( com_name, com_email, com_dis, post_id_fk ) VALUES ( :name, :email, :com_dis, :id )';
    $st = $conn->prepare ( $sql );
$st->bindValue( ":name", $name, PDO::PARAM_STR );
    $st->bindValue( ":email", $email, PDO::PARAM_STR );
    $st->bindValue( ":com_dis", $com_dis, PDO::PARAM_STR );
    $st->bindValue( ":id", $id, PDO::PARAM_INT );
    $st->execute();
    $conn = null;
}catch(PDOException $e ){
    echo "QUERY FAILED" . $e->getMessage();
};

如果我使用$id = $_POST['id']所有变量,它会抛出一个未识别的索引错误。当我打印$_POST时,它会显示一个数组,其中数组称为名称,内容只是其余的变量,它们是存储在表中的相同数据。

如何让数据正确保存或停止$_POST合并变量?保存在正确的列中?

这是我的表格:

<form action="#" method="post">
    <input type="hidden" name="id" id="id" value="<?php echo $id; ?>"/><br />
    <span class="titles">Name</span><span class="star">*</span><br /><input type="text" name="name" id="name"/><br />

    <span class="titles">Email</span><span class="star">*</span><br /><input type="text" name="email" id="email"/><br />

    Comment<br /><textarea name="comment" id="comment"></textarea><br />

    <input type="submit" class="submit" value=" Submit Comment " />
</form>

表单通过 AJAX 传递:

$(function() {

    $(".submit").click(function() {

        name = $("#name").val();
        var email = $("#email").val();
        var comment = $("#comment").val();
        var id = $("#id").val();
        var dataString = 'name='+ name + 'email=' + email + 'comment=' + comment + 'id=' + id;

        if(name=='' || email=='' || comment==''){
            alert('Please Give Valid Details');
        }

        else{
            $("#flash").show();
            $("#flash").fadeIn(400).html('<img src="ajax-loader.gif" align="absmiddle">&nbsp;<span class="loading">Loading Comment...</span>');

            $.ajax({
                type: "POST",
                url: "commentajax.php",
                data: dataString,
                cache: false,
                success: function(html){

                    $("ol#update").append(html);
                    $("ol#update li:last").fadeIn("slow");
                    document.getElementById('email').value='';
                    document.getElementById('name').value='';
                    document.getElementById('comment').value='';
                    $("#name").focus();

                    $("#flash").hide();
            }
        });
    }
return false;
});
4

1 回答 1

3

您需要连接您的数据字符串:

var dataString = 'name='+ name + 'email=' + email + 'comment=' + comment + 'id=' + id;

应该

var dataString = 'name='+ name + '&email=' + email + '&comment=' + comment + '&id=' + id;
于 2013-01-05T18:59:37.367 回答