1

我在 html 中有我的注册表单所有设置和工作,它第一次运行并在 mysql 表中插入一行,但我不能再插入任何行。

我的PHP是: -

include "config.php";

$gamerid = $_POST['gamerid_create'];
$email = $_POST['email_create'];
$password = md5($_POST['password_create']);
$country = $_POST ['country_create'];

echo "<pre>";
print_r($_POST);
echo "</pre>";

$insert = "insert into users (gamerid,email,password,country) values('$gamerid','$email','$password','$country')";
mysql_query($insert);

现在,当我在 mysql 中创建表时,我使用了以下代码:-

CREATE TABLE users
(
id INT primary key NOT NULL AUTO_INCREMENT,
gamerid varchar (255) NOT NULL,
email varchar (255) NOT NULL,
password varchar (255) NOT NULL,
country varchar (255) NOT NULL
)

为什么不插入更多行?

我的html如下:

<form id = "signup_form" method = "POST" action = "http://localhost:8080/quizicle/pages/register.php">
<table id = "signup_form_table" border = "0" class = "signup_table_body">
<tr class = "signup_form_tr_label">
<td class = "signup_form_td"><label for "gamerid" class = "signup_form_label">Create a Gamer ID:</label></td>
<td class = "signup_form_td"><label for "email" class = "signup_form_label">Your Email:</label></td>
<td class = "signup_form_td"><label for "password" class = "signup_form_label">Password:</label></td>
<td class = "signup_form_td"><label for "country" class = "signup_form_label">Country:</label></td>
<td class = "signup_form_td"></td>
</tr>

<tr class = "signup_form_tr">
<td class = "signup_form_td"><input type = "text" name = "gamerid_create" id = "gamerid_create" maxlength="50" class = "signup_form_input"/></td>
<td class = "signup_form_td"><input type = "text" name = "email_create" id = "email_create" maxlength="50" class = "signup_form_input"/></td>
<td class = "signup_form_td"><input type = "password" name = "password_create" id = "password_create" maxlength="50" class = "signup_form_input"/></td>
<td class = "signup_form_td">
<select name = "country_create">                                    <option>Please select a country</option> 
<option>United Kingdom</option> 
</select>
</td>
<td class = "signup_form_td"><input type = "submit" value = "Sign me up!" id = "btn_register" value = "register" class = "signup_form_submit_btn"/></td>
</tr>   
</table>
</form>
4

2 回答 2

0
    <?php

include "config.php";

// INPUT CLEANING FUNCTION
function clean($str)
{
    $cleaned = mysql_real_escape_string(strip_tags($str));
    return $cleaned;
}

$gamerid = clean($_POST['gamerid_create']);
$email = clean($_POST['email_create']);
$password = clean(md5($_POST['password_create']));
$country = clean($_POST ['country_create']);


$insert = "insert into users(gamerid,email,password,country) values('$gamerid' ,'$email',' $password', '$country')";                        
mysql_query($insert);
?>
  1. 检查您的 id 字段是否为自动增量
  2. 检查输入标签或文本区域标签的属性名称 // 可选建议
  3. 使用 php 内置的 filter_var 函数验证电子邮件
  4. 验证密码长度和强度
  5. 还要考虑一些命名约定
  6. 使用框架 CODEIGNITER 或 LARAVEL
于 2012-10-19T18:34:50.953 回答
-1

这可能与您的主键有关id

让我们改变一下sql,看看它是否有效。

$insert = "INSERT INTO users (id, gamerid, email, password, country) 
  VALUES (NULL, '{$_POST['gamerid_create']}', '{$_POST['email_create']}', 
  '{$_POST['password_create']}', '{$_POST['country_create']}');";

在开发 PHP / MySQL 技能时,您应该考虑一些事项:

  • 验证并清理您的用户输入。Sql 注入风险。请参阅:mysql_real_escape_string(),在此处获取基本帮助。

  • 您应该配置您的表格,确保将字段类型和大小设置为您需要的最小值,如果您不全部填写,VARCHAR(255) 将浪费大量空间。

  • 始终使用至少 md5 算法散列密码。

于 2012-10-19T18:31:27.190 回答