1

我有这个页面从 html 表单插入数据。没有显示错误,但也没有插入数据。这是我给出的代码。

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

$queryUserType = "select * from user_type";
$resultUserType = mysql_query($queryUserType) or die(mysql_error());

$queryTitle = "select * from name_titles";
$resultTitle = mysql_query($queryTitle) or die(mysql_error());

$time = time();
$date = date("d-m-y");
$nowDateTime=$time.$date;

if($_REQUEST['btnUserSubmit'])
{
    $queryInsertUser="INSERT INTO  users (`title_id`, `first_name`, `last_name`, `email`, `utid`, `residence_address1`, `residence_address2`, `residence_city`, `residence_state`, `residence_country`, `residence_zipcode`, `phone_no`, `username`, `password`, `created`, `date_of_birth`, `gender` ) VALUES ('".mysql_real_escape_string($_REQUEST['$rowTitle[0]'])."', '".mysql_real_escape_string($_REQUEST['txtFirstName'])."', '".mysql_real_escape_string($_REQUEST['txtLastName'])."', '".mysql_real_escape_string($_REQUEST['txtEmail'])."', '".mysql_real_escape_string($_REQUEST['rowUserType[0]'])."', '".mysql_real_escape_string($_REQUEST['txtAddressLine1'])."', '".mysql_real_escape_string($_REQUEST['txtAddressLine2'])."', '".mysql_real_escape_string($_REQUEST['txtCity'])."', '" .mysql_real_escape_string($_REQUEST['txtState'])."', '".mysql_real_escape_string($_REQUEST['txtCountry'])."', '".mysql_real_escape_string($_REQUEST['txtPhone'])."', '".mysql_real_escape_string($_REQUEST['txtUserName'])."', '".mysql_real_escape_string($_REQUEST['txtUserPassword'])."', '".$nowDateTime."', '".mysql_real_escape_string($_REQUEST['txtdateofbirth'])."', '".mysql_real_escape_string($_REQUEST['rdGender'])."');";

$resultinsert=mysql_query($queryInsertUser) or die(mysql_error());
}
?>

我在页面重定向的地方没有任何问题。表单验证仍然存在。在这个表中,只有 email、utid、username、password 这四个字段不为空。其余为 Null 允许。

4

3 回答 3

7

如您所见,您缺少的字段 11,见下文:

<?php
$QueryCol   = array('title_id',             // Field 1
                    'first_name',           // Field 2
                    'last_name',            // Field 3
                    'email',                // Field 4
                    'utid',                 // Field 5
                    'residence_address1',   // Field 6
                    'residence_address2',   // Field 7
                    'residence_city',       // Field 8
                    'residence_state',      // Field 9
                    'residence_country',    // Field 10
                    'residence_zipcode',    // Field 11
                    'phone_no',             // Field 12
                    'username',             // Field 13
                    'password',             // Field 14
                    'created',              // Field 15
                    'date_of_birth',        // Field 16
                    'gender');              // Field 17

$QueryData  = array((isset($_REQUEST[$rowTitle[0]])      ? $_REQUEST[$rowTitle[0]]          : null),    // Field 1
                    (isset($_REQUEST['txtFirstName'])    ? $_REQUEST['txtFirstName']        : null),    // Field 2
                    (isset($_REQUEST['txtLastName'])     ? $_REQUEST['txtLastName']         : null),    // Field 3
                    (isset($_REQUEST['txtEmail'])        ? $_REQUEST['txtEmail']            : null),    // Field 4
                    (isset($_REQUEST[$rowUserType[0]])   ? $_REQUEST[$rowUserType[0]]       : null),    // Field 5
                    (isset($_REQUEST['txtAddressLine1']) ? $_REQUEST['txtAddressLine1']     : null),    // Field 6
                    (isset($_REQUEST['txtAddressLine2']) ? $_REQUEST['txtAddressLine2']     : null),    // Field 7
                    (isset($_REQUEST['txtCity'])         ? $_REQUEST['txtCity']             : null),    // Field 8
                    (isset($_REQUEST['txtState'])        ? $_REQUEST['txtState']            : null),    // Field 9
                    (isset($_REQUEST['txtCountry'])      ? $_REQUEST['txtCountry']          : null),    // Field 10
                                                                                                        // Field 11
                    (isset($_REQUEST['txtPhone'])        ? $_REQUEST['txtPhone']            : null),    // Field 12
                    (isset($_REQUEST['txtUserName'])     ? $_REQUEST['txtUserName']         : null),    // Field 13
                    (isset($_REQUEST['txtUserPassword']) ? $_REQUEST['txtUserPassword']     : null),    // Field 14
                    $nowDateTime,                                                                       // Field 15
                    (isset($_REQUEST['txtdateofbirth'])  ? $_REQUEST['txtdateofbirth']      : null),    // Field 16
                    (isset($_REQUEST['rdGender'])        ? $_REQUEST['rdGender']            : null);    // Field 17

foreach($QueryData as $Key => $Value){
    $QueryData[$Key] = mysql_real_escape_string($Value);
}

$QueryInsertUser    =   'INSERT INTO users (`'.implode('`, `', $QueryCol).'`)'.
                        'VALUES ("'.implode('", "', $QueryData).'")';
$resultinsert       =   mysql_query($QueryInsertUser)
                        or die(mysql_error());

?>

尖端 :

  1. 停止使用 $_REQUEST。使用 $_GET 或 $_POST
  2. 避免像以前那样使用大线。您无法快速找到错误。
  3. 使用数组编写更少的代码。
  4. 使用array_walk函数将函数映射到数组中的每个条目。
  5. 让你的代码读起来更甜,更容易调试
  6. 像这样的变量$_REQUEST['$Blabla']不起作用,因为使用 ' 不适用于解析变量,请使用 " 代替那样$_REQUEST["{$Blabla}"]。但是,避免这种情况,因为 PHP 需要解析意味着需要更多的动力,请$_REQUEST[$Blabla]改用。
  7. 在开发过程中,我建议您在脚本顶部使用以下几行:

    error_reporting(-1);
    ini_set('display_errors', 'On');
    

    它将显示所有错误。即使不是真正的错误。它将帮助您编写可以在任何地方工作的完美代码和标准代码。

  8. 对于每个 $_POST、$_GET、$_REQUEST、$_FILES 等,请使用函数isset,因为它会产生错误。
  9. 请记住,每个错误都会使页面加载时间加倍。尝试创建一个页面,假设 10000 行没有错误,平均可能是 0.01 秒。每行有一个错误,可能需要 0.5 秒。看那个。
于 2012-04-24T17:30:24.857 回答
0

你试过改变吗

if($_REQUEST['btnUserSubmit'])

if (isset($_POST['btnUserSubmit']))

?

编辑!

我也认为在您的 INSERT 查询结束时

'".mysql_real_escape_string($_REQUEST['rdGender'])."');";

你可以替换为:

'".mysql_real_escape_string($_REQUEST['rdGender'])."')"; // Lose the ; after "')

你为什么不直接使用 $_POST[]; 而不是 $_REQUEST[]; ?

于 2012-04-24T17:20:06.137 回答
0

尝试删除行尾的第一个分号,使其如下所示:

...($_REQUEST['rdGender'])."')";
于 2012-04-24T17:23:31.650 回答