PHP中,为何当3个输入框都是空的时候,我点击提交,依然会往数据库写一行(都是空的)???-问答-阿里云开发者社区-阿里云

开发者社区> 问答> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

PHP中,为何当3个输入框都是空的时候,我点击提交,依然会往数据库写一行(都是空的)???

2016-03-09 11:22:43 2062 1

screenshot

 <!DOCTYPE html>
<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
    <style>.error {color: red;}</style>
</head>
<body>


    <?php 
//检查(1)邮箱、密码、昵称是否为空;(2)邮箱格式是否正确。
global $emailErr,$passErr,$nicknameErr; 
$emailErr = $passErr = $nicknameErr = "";
//$user_email = $user_pass = $user_nickname = "";

if (empty($_POST["user_email"]))        {$emailErr = "不可为空";}
    else 
    {
        if (!preg_match("/^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*/",$_POST["user_email"])) {$emailErr = "email格式不正确";} 
        else {$emailErr="ok";} 
    }
if (empty($_POST["user_pass"]))         {$passErr = "不可为空";}        else {$passErr = "ok";}
if (empty($_POST["user_nickname"]))     {$nicknameErr = "不可为空";}    else {$nicknameErr = "ok";}
?>


<form method="post" action="<?php echo htmlspecialchars($_SERVER["PHP_SELF"]);?>">               
<p>注册一个新用户^_^</p>   
邮箱:<input type="text" name="user_email"><span class="error">*         <?php echo $emailErr;?></span><br><br>
密码:<input type="text" name="user_pass"><span class="error">*      <?php echo $passErr;?></span><br><br>
昵称:<input type="text" name="user_nickname"><span class="error">*  <?php echo $nicknameErr;?></span><br><br>
      <input type="submit" name ='submit' value="注册">
</form>


<?php
if ( isset($_POST["submit"]) && $emailErr="ok" && $passErr = "ok" && $nicknameErr = "ok" )
{
//连接数据库
$con = mysql_connect(SAE_MYSQL_HOST_M.":".SAE_MYSQL_PORT,SAE_MYSQL_USER,SAE_MYSQL_PASS);
$con or die ('Could not connect: ' . mysql_error());

//选择数据库
mysql_select_db(SAE_MYSQL_DB,$con);

//获取当前时间戮
$unix_timestamp=time();

//插入用户注册数据
$sql="INSERT INTO users 
(user_email,user_pass,user_nickname,user_reg_ip,user_reg_date,user_last_log_ip,user_last_log_date,user_coins,user_rmb,user_email_status)
VALUES
('$_POST[user_email]','$_POST[user_pass]','$_POST[user_nickname]','$_SERVER[REMOTE_ADDR]','$unix_timestamp','$_SERVER[REMOTE_ADDR]','$unix_timestamp','0','0','0')";

if (!mysql_query($sql,$con))
  {
  die('Error: ' . mysql_error());
  }
echo "注册成功!";

//断开数据库连接
mysql_close($con);

}
else echo "not coming..";

?>
<br>
很高兴遇见你,<?php echo $_POST["user_nickname"]; ?><br>
<a href="#">点此登陆...>>></a>
</body>
</html>
取消 提交回答
全部回答(1)
  • 小旋风柴进
    2019-07-17 18:55:39
    if (empty($_POST["user_email"]))
    
    {
    $emailErr = "不可为空";
    }
    else 
    {
    if (!preg_match("/^\w+([-+.]\w+)*@\w+([-.]\w+)*.\w+([-.]\w+)*/",$_POST["user_email"])) {$emailErr = "email格式不正确";} 
    else {$emailErr="ok";} 
    }

    先对齐代码,然后,朋好,你看,你只是返回错误,并没有让程序停止运行,而你数据库设计时应该也没有设置not null,那么就写进去喽,建议你写入时判断下err字段是否为空呗

    0 0
相关问答

2

回答

PHP连不上数据库

2018-10-04 09:43:46 1867浏览量 回答数 2

6

回答

php连不上数据库

2018-10-04 09:45:32 2280浏览量 回答数 6

1

回答

发布的网站无法访问(本机和其它电脑都不能访问),网站项目开发(php+mysql)

2018-09-06 06:13:34 677浏览量 回答数 1

3

回答

php代码 sql数据库 打开页面提示 系统不支持:mysql

2018-09-04 17:46:26 1648浏览量 回答数 3

2

回答

云服务器ECS能自己配置Apache+PHP+mysql运行环境吗?

2018-08-24 08:30:39 534浏览量 回答数 2

1

回答

支持PHP 7.2和MySQL 5.6的主机

2018-08-25 01:20:00 809浏览量 回答数 1

1

回答

云虚拟主机主机php版本及MySQL版本

2018-08-23 15:43:46 1266浏览量 回答数 1

1

回答

mac 如何升级和自由配置自带的php mysql

2018-07-07 08:32:36 4287浏览量 回答数 1

3

回答

如何将php+mysql网站上传至云服务器ecs上

2018-02-27 21:38:08 2694浏览量 回答数 3

1

回答

php连接mysql识别不到端口号

2016-02-07 11:51:37 2248浏览量 回答数 1
2709
文章
6591
问答
问答排行榜
最热
最新
相关电子书
更多
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
冬季实战营第三期:MySQL数据库进阶实战
立即下载