- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试构建一个方法来检查用户是否存在,如果存在,则从数据库返回他们的 ID。过去我总是在查询后使用mysql_fetch_array,然后我会使用array_shift($result_array)来获取id。事实证明,这对准备好的陈述来说是一个挑战。看一下我的方法:
<?php
require_once("db.php");
class User extends Database{
public $dbFields = array('username', 'password');
public $tableName = "users";
public $id;
public $username;
public $password;
// public function auth($user, $pass){
// $this->username = $user;
// $this->password = $pass;
// }
public function authenticate($username = '', $password = ''){
if(!empty($username) && !empty($password)){
$stmt = "SELECT * FROM users ";
$stmt .= "WHERE username =:username ";
$stmt .= "AND password =:password ";
$stmt = $this->db->prepare($stmt);
if($result = $stmt->execute(array(':username' => $username, ':password' => $password))){
if ($result = $stmt->fetch(PDO::FETCH_ASSOC)){
return $result;
} else {
return print("false");
}
}else{
return print("false false");
}
}
}
}
?>
这可能不相关,但这是表单页面:
if (isset($_POST['submit'])){
$username = $_POST['username'];
$password = $_POST['password'];
$user = new User();
$user->authenticate($username, $password);
}
?>
<html>
<head>
<title>test</title>
</head>
<body>
<form action = "test.php" method= "POST" accept-charset="utf-8" >
<p>Username
<input type="text" name="username" maxlength="30" value="" />
</p>
<p>Password
<input type="password" name="password" maxlength="30" value="" />
</p>
<p><input type="submit" name="submit" value="Continue →"></p>
</form>
</body>
</html>
我已经在所有其他数据库方法上成功使用了 pdo,所以如果可以的话,我真的不想切换回标准 mysql 语句。有什么建议吗?
编辑:按照 Chris 的建议更改了执行数组中的语法。
最佳答案
php 不会扩展由单引号分隔的字符串中的变量。
使用类似的东西
array(':username' => $username, ':password' => $password)
除此之外,您的变量 $result 是一个关联数组,就像您习惯的那样。
return $result['id'];
注意,打印函数返回值 1。我真的不认为您希望从验证函数返回该值。你如何判断 1 是某人的用户 ID,还是 print 的返回值?返回 bool 值 false 来代替指示失败。
关于php - 如何返回 pdo 准备好的语句来检查用户是否存在,然后从数据库返回 id?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8389557/
我想获取当前位置并将相机移动到当前位置,然后将当前位置 (LatLng) 保存到我的数据库 我获得了 ACCESS_FINE 权限并使用以下代码,但应用程序已停止工作 double lat = map
我想稍微优化一下这部分代码,以使用 $_SESSION['user']= $arr; 这样的数组。 // Store user db info in session for use $stmt = $
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我不确定 DaemonSet 中是否存在就绪条件。我的意思是,该 DaemonSet 拥有的所有 pod 都已准备就绪。 我知道 kubectl wait ,不过好像不能检查 DaemonSet 的准
我正在编写一个 JS 模块模式来测试代码并帮助我使用 JS Fiddle 理解该模式。我不明白的是,为什么第 25 行和第 26 行的“私有(private)方法”在通过 DOM 就绪引用时,其值为未
标题中有一个非常微妙的动画。当第一次加载页面,或者使用 cmd+shift+r (mac) 刷新以清除缓存时,jQuery 似乎并没有等待 DOM 准备好。它在所有正常的 html/css 弹出之前启
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
我有两个问题: 我如何知道框架的内容已准备就绪/已加载(如 $(document.ready()))? 我如何知道弹出窗口 (window.open()) 内容已准备就绪/已加载(如 $(docume
只是想知道 document.ready 调用的数量是否会影响页面加载速度。Gulp/Grunt 有没有办法通过删除单独的文档就绪函数来丑化/缩小 JS? 最佳答案 检查一下! 我没有发现 Chrom
我有一个 的列表如下所示,它使用 Meteor.startup 填充了 find()。然后我得到这些 的所有数据属性使用 data() 并将其放入一个对象中并尝试返回/console.log 它以
我正在使用 trego 主题。作为主题选项,您可以设置和更改将出现在站点中的文本(例如“版权文本”和“ Logo url”的文本)。我如何使用 WPML 制作多语言版本?我想通过 wpml-confi
Zend_Service_Twitter 组件仍然适用于将于 2013 年 3 月 5 日弃用的 Twitters API v1.0。所以我想准备好我的新网站与 Twitter API 交互 v1.1
有没有一种优雅的方法来做到这一点?目前我只是使用自定义步骤 “并等待 10 秒”以绝对确定,有足够的时间让 iframe 做好准备。我不希望这个功能因为一个小的网络问题或 CPU 峰值而在我动力不足的
当我尝试在我的 VPS 上安装 Windows 时,我无法访问 Glish---图形网站控制台(但浏览器控制台可以工作)。 当我打开 Glish 控制台时,提示: novnc ready: nativ
生成新的全屏窗口时,相对于: sdl2.SDL_Init(sdl2.SDL_INIT_VIDEO) window = sdl2.ext.Window('win_name', (x_size, y_si
我刚刚为我的最新项目投入了 Umbraco ASP.NET CMS,我不确定这是否是全面的,但对于我的设置,Knockout.js 正在做所有的模板。 我不太热衷于 knockout.js,但到目前为
我是 jQuery 的新手,最近几天一直在尝试学习它。在我的办公室里,几乎没有经验丰富的 JavaScript 开发人员,他们主要使用 jQuery 来满足他们的所有需求,每当我找到他们并与他们交谈以
我目前正在编写一个脚本,我正在使用 while($IE.busy) {Start-Sleep 1} 等待页面准备就绪。 页面准备好后,我的脚本会填写并提交表单。我一直遇到问题,因为(我认为)IE 报告
这个问题已经有答案了: window.onload vs $(document).ready() (17 个回答) 已关闭 3 年前。 以下示例代码的执行顺序是什么?会$(window).on('lo
我是一名优秀的程序员,十分优秀!