Php 捕获用户上次登录日期
如何记录用户的上次登录日期?我尝试使用Php 捕获用户上次登录日期,php,mysql,sql,Php,Mysql,Sql,如何记录用户的上次登录日期?我尝试使用$query=“UPDATE users SET lastloginandate=NOW(),其中username=“username”对其进行测试,但不幸的是没有任何效果。显然,我还想确保正确记录已验证用户的日期 我应该把它放在这个脚本的什么地方 <?php require("config.php"); $submitted_username = ''; if(!empty($_POST)){ $que
$query=“UPDATE users SET lastloginandate=NOW(),其中username=“username”
对其进行测试,但不幸的是没有任何效果。显然,我还想确保正确记录已验证用户的日期
我应该把它放在这个脚本的什么地方
<?php
require("config.php");
$submitted_username = '';
if(!empty($_POST)){
$query = "
SELECT
id,
username,
password,
salt,
email
FROM users
WHERE
username = :username
";
$query_params = array(
':username' => $_POST['username']
);
try{
$stmt = $db->prepare($query);
$result = $stmt->execute($query_params);
}
catch(PDOException $ex){ die("Failed to run query: " . $ex->getMessage()); }
$login_ok = false;
$row = $stmt->fetch();
if($row){
$check_password = hash('sha256', $_POST['password'] . $row['salt']);
for($round = 0; $round < 65536; $round++){
$check_password = hash('sha256', $check_password . $row['salt']);
}
if($check_password === $row['password']){
$login_ok = true;
}
}
if($login_ok){
unset($row['salt']);
unset($row['password']);
$_SESSION['user'] = $row;
$query = "UPDATE users SET lastlogindate = NOW() WHERE username = "deason";
header("Location: main.php");
die("Redirecting to: main.php");
}
else{
print("Login Failed.");
$submitted_username = htmlentities($_POST['username'], ENT_QUOTES, 'UTF-8');
}
}
?>
突出显示的语法泄露了这一点:这是一个引号问题。您在查询中对字符串和字符串值使用双引号
$query = "UPDATE users SET lastlogindate = NOW() WHERE username = "deason";
应该是:
$query = "UPDATE users SET lastlogindate = NOW() WHERE username = 'deason'";
通常,您必须添加引号:
$query = "UPDATE `users` SET `lastlogindate` = NOW() WHERE `username` = 'deason'";
使用PDO的prepare时会自动添加引号。只有在该查询中没有保留关键字的情况下才需要反勾号。然后您使用的是保留关键字,或者您有一个名称不清楚的方案。-)嗨,John,查询的位置正确吗?当作为查询插入Mysql控制台时,它会工作