错误代码
<?php/** * Created by PhpStorm. * User: Administrator * Date: 2015/8/16 * Time: 15:37 */if(!isset($_POST['name'])){ die('user name not define');}if(!isset($_POST['password'])){ die('user name not define');}if(empty($_POST['name'])){ die('user name is empty');}if(empty($_POST['password'])){ die('user password is empty');}require_once 'connect_server.php';connectdb();$name=$_POST['name'];$password=$_POST['password'];$sql="select * from users WHERE name=$name AND password=$password";$result=mysql_query($sql);$new=mysql_fetch_assoc($result);if($new['name']==$name&&$new['password']==$password){ echo "<script>alert('登陆成功');window.location='zhuye.php'</script>";}else{ echo "<script>alert('登陆失败');window.location='zhuye.html'</script>";}
可运行代码
<?phprequire_once 'function.php'?><!DOCTYPE html><html><head> <meta charset="UTF-8"> <title>所有用户</title></head><body><a href="adduser.html">添加用户</a><?php$conn=connectDb();mysql_select_db('test',$conn);$result=mysql_query("SELECT * FROM users",$conn);$dataCount=mysql_num_rows($result);echo"<table border='1'>";for($i=1;$i<$dataCount;$i++){ $result_arr=mysql_fetch_assoc($result); $id=$result_arr['id']; $name=$result_arr['name']; $age=$result_arr['age']; echo"<tr><td>$id</td><td>$name</td><td>$age</td><td><a href='edituser.php?id=$id>'>修改</a><br> <a href='deleteuser.php?id=$id>'>删除</a> </td></tr>";}echo"</table>";?></body></html>
两段代码中的mysql_query的返回值一样,但是为什么一段函数在调用其返回值的时候出现警告如图
回复讨论(解决方案)
"select * from users WHERE name=$name AND password=$password"
上面的代码是有问题的,name和password没有加引号,导致sql语法错误,最终没有返回资源类型,而返回了布尔值false
正确的代码应该是
"select * from users WHERE 'name'=$name AND 'password'=$password"
$sql="select * from users WHERE name=$name AND password=$password";
改为:
$sql="select * from users WHERE name='".$name."' AND password='".$password."'";
因为你$name,$password如果为空,会造成语法错误。
还是错的?把sql语句再改成这样试试,应该是$name和$password没有被当成字符串导致出错。。。
"select * from users WHERE 'name'=".$name." AND 'password'=".$password
还是错的?把sql语句再改成这样试试,应该是$name和$password没有被当成字符串导致出错。。。
"select * from users WHERE 'name'=".$name." AND 'password'=".$password
我又写错了。。。应该是这样
"select * from users WHERE name='".$name."' AND password='".$password."'";
还是错的?把sql语句再改成这样试试,应该是$name和$password没有被当成字符串导致出错。。。
"select * from users WHERE 'name'=".$name." AND 'password'=".$password
我又写错了。。。应该是这样
"select * from users WHERE name='".$name."' AND password='".$password."'";可否告知为什么
$sql="select * from users WHERE name=$name AND password=$password";
改为:
$sql="select * from users WHERE name='".$name."' AND password='".$password."'";
因为你$name,$password如果为空,会造成语法错误。
还是错的?把sql语句再改成这样试试,应该是$name和$password没有被当成字符串导致出错。。。
"select * from users WHERE 'name'=".$name." AND 'password'=".$password
我又写错了。。。应该是这样
"select * from users WHERE name='".$name."' AND password='".$password."'";可否告知为什么
因为$name和$password在sql语句中应该是以字符串的形式出现的(也就是说得有单引号包起来$name和$password的值)
还是说,你想知道为什么要那么拼接单引号和双引号?
还是错的?把sql语句再改成这样试试,应该是$name和$password没有被当成字符串导致出错。。。
"select * from users WHERE 'name'=".$name." AND 'password'=".$password
我又写错了。。。应该是这样
"select * from users WHERE name='".$name."' AND password='".$password."'";可否告知为什么
因为$name和$password在sql语句中应该是以字符串的形式出现的(也就是说得有单引号包起来$name和$password的值)
还是说,你想知道为什么要那么拼接单引号和双引号? 我想知道为什么拼接单引号和双引号还有为什么要用将变量放在..的中间,两个点的作用是什么
$sql="select * from users WHERE name=$name AND password=$password";
如果是数值型的$name和$password变量,可以在SQL语句中直接使用,如果是字符串类型的变量,需要加单引号
我把代码拆成三段,你应该能明白了。两个那个点是用来连接字符串的,意思是告诉PHP:点之后的变量是个字符串
"select * from users WHERE name='"
"' AND password='"
"'"
就是说,每个单引号 / 双引号碰到第二个单引号 / 双引号时,那一段字符就结束了。这三段都是一个双引号里包单引号。。
我把代码拆成三段,你应该能明白了。两个那个点是用来连接字符串的,意思是告诉PHP:点之后的变量是个字符串
"select * from users WHERE name='"
"' AND password='"
"'"
就是说,每个单引号 / 双引号碰到第二个单引号 / 双引号时,那一段字符就结束了。这三段都是一个双引号里包单引号。。 懂了~谢谢

长URL(通常用关键字和跟踪参数都混乱)可以阻止访问者。 URL缩短脚本提供了解决方案,创建了简洁的链接,非常适合社交媒体和其他平台。 这些脚本对于单个网站很有价值

Laravel使用其直观的闪存方法简化了处理临时会话数据。这非常适合在您的应用程序中显示简短的消息,警报或通知。 默认情况下,数据仅针对后续请求: $请求 -

这是有关用Laravel后端构建React应用程序的系列的第二个也是最后一部分。在该系列的第一部分中,我们使用Laravel为基本的产品上市应用程序创建了一个RESTFUL API。在本教程中,我们将成为开发人员

Laravel 提供简洁的 HTTP 响应模拟语法,简化了 HTTP 交互测试。这种方法显着减少了代码冗余,同时使您的测试模拟更直观。 基本实现提供了多种响应类型快捷方式: use Illuminate\Support\Facades\Http; Http::fake([ 'google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

PHP客户端URL(curl)扩展是开发人员的强大工具,可以与远程服务器和REST API无缝交互。通过利用Libcurl(备受尊敬的多协议文件传输库),PHP curl促进了有效的执行

您是否想为客户最紧迫的问题提供实时的即时解决方案? 实时聊天使您可以与客户进行实时对话,并立即解决他们的问题。它允许您为您的自定义提供更快的服务

2025年的PHP景观调查调查了当前的PHP发展趋势。 它探讨了框架用法,部署方法和挑战,旨在为开发人员和企业提供见解。 该调查预计现代PHP Versio的增长

在本文中,我们将在Laravel Web框架中探索通知系统。 Laravel中的通知系统使您可以通过不同渠道向用户发送通知。今天,我们将讨论您如何发送通知OV


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

安全考试浏览器
Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

SublimeText3 Linux新版
SublimeText3 Linux最新版

SublimeText3汉化版
中文版,非常好用

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)