php帮我看一下,receive这个文件里的16,17行哪里出错了,注册相同用户名他就报错
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了php帮我看一下,receive这个文件里的16,17行哪里出错了,注册相同用户名他就报错,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2513字,纯文字阅读大概需要4分钟。
内容图文
![php帮我看一下,receive这个文件里的16,17行哪里出错了,注册相同用户名他就报错](/upload/InfoBanner/zyjiaocheng/209/97521c270c7c4499902c89e7bb3f49c5.jpg)
登录|注册
欢迎注册
receive.php
if(isset($_POST['submit'])) {
session_start();
$checkstr = $_SESSION['yzm']; //使用$_SESSION变量获取03.php页面上的验证码
$str = $_POST['check']; //用户输入的字符串
if (strcasecmp($str, $checkstr) != 0) //不区分大小写进行比较
echo "";
else {
$username = $_POST["username"];
$password = $_POST["psw1"];
$email = $_POST["email"];
$dsn="mysql:host=localhost;dbname=book";
$db=new PDO($dsn,'root','123456');
$db->query('set names utf8');
16行 : $chkusername = mysql_query("select username from register where username=".$username."");
17行: $numrow = mysql_num_rows($chkusername);
if( $numrow != 0 ) {
print("
");
}
else {
$sql = "insert into register(username,password,email) VALUES (?,?,?)";
$stmt=$db->prepare($sql);
$stmt->bindParam(1,$username);
$stmt->bindParam(2,$password);
$stmt->bindParam(3,$email);
$stmt->execute();
$_SESSION['username'] = $username;
print("
");
}
}
}
else echo"非法访问";
?>
回复讨论(解决方案)
你是这样连接数据库的
$dsn="mysql:host=localhost;dbname=book";
$db=new PDO($dsn,'root','123456');
$db->query('set names utf8');
然后却这样进行操作
16行 : $chkusername = mysql_query("select username from register where username=".$username."");
17行: $numrow = mysql_num_rows($chkusername);
你认为这样做合适吗?
SQL语句也要改,除非你的username是数字,不然需要加上单引号
$sql = "select username from register where username = '{$username}'";
链接pdo 使用用原生
17行要怎么改呢,谁能给出个改过的16行,17行出来给我看下
终于改好了!
你是用pdo连接 用原生方法执行sql 必然会出错的
内容总结
以上是互联网集市为您收集整理的php帮我看一下,receive这个文件里的16,17行哪里出错了,注册相同用户名他就报错全部内容,希望文章能够帮你解决php帮我看一下,receive这个文件里的16,17行哪里出错了,注册相同用户名他就报错所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。