一个因为全角和半角空格引发的bug

先贴上PHP代码,这是有问题的代码!
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<link href="../CSS/style.css" rel="stylesheet" type="text/css"/>
<title>title</title>
</head>
<body >
<?php
session_start();
include "database/con_db.php";
$username='a';
$result = mysql_query("select * from user");
while($query = mysql_fetch_array($result)){
  if($query['user']==$username){
  	if($query['password']==$password){
  		echo "登录成功";

  		return;
  	}
  	else{
  		echo "密码错误";
  		return;
  	}
  }
}
echo "用户不存在";
return;
?>
</body>
</html>

运行之后的错误为:


Warning: mysql_fetch_array() expects parameter 1 to be resource, boolean given in D:\wamp\www\notice\php\check_login.php on line 16

经过调试之后,发现竟然是12行select语句星号后面有个空格为全角空格!!

长知识了!这两个空格是不一样的->" "" "如果你错误输入了全角空格,就会报错!

查了一下两者的不同:

字符集不同,半角属于英文的 全角是中文的,半角是ascall的编码,全角会识别成中文,是UTF-8或者GBK系列,所以会报这种错!

记之以警己!



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值