php 类 传递变量,php – 没有传递给类方法的变量

我正在使用PHP构建一个登录类,但是当我将它们传递给类方法时使用的变量是空的,即使它们不应该.

我尝试只返回$username变量,但它仍然是空的,但如果我不使用类返回它,我可以看到它被正确分配.

我正在使用多个其他类以及正确分配变量的方法.

我不知道自己是否瞎了眼,错过了一些显而易见的东西,或者是否还有其他因素造成的.

class Auth

{

private $mysqli;

public function __construct(mysqli $mysqli)

{

$this->mysqli = $mysqli;

}

public function login($username, $password) //These variables are empty, even when they shouldn't be

{

$return['error'] = true;

$uid = $this->getUserId(strtolower($username)); //Returns false because $username variable is empty

if (!$uid) {

$return['message'] = 'No such user.'; //Output

return $return;

}

$user = $this->getUser($uid);

if (!password_verify($password, $user['password'])) {

$return['message'] = 'Password incorrect';

return $return;

}

$return['error'] = false;

$return['message'] = 'Logged in';

return $return;

}

private function getUserId($username)

{

$stmt = $this->mysqli->prepare("SELECT id FROM users WHERE username = ?");

$stmt->bind_param('s', $username);

$stmt->execute();

$stmt->store_result();

$stmt->bind_result($id);

if ($stmt->num_rows < 1) {

return false;

}

$stmt->fetch();

return $id;

}

private function getUser($uid)

{

$stmt = $this->mysqli->prepare("SELECT username, password, email FROM users WHERE id = ?");

$stmt->bind_param('s', $uid);

$stmt->execute();

$stmt->store_result();

$stmt->bind_result($username, $password, $email);

if ($stmt->num_rows < 1) {

return false;

}

$stmt->fetch();

$return['uid'] = $uid;

$return['username'] = $username;

$return['password'] = $password;

$return['email'] = $email;

return $return;

}

}

表单分配发送的变量.

Username

Password

Log in

if (isset($_POST['username'])) {

$username = $_POST['username'];

$password = $_POST['password'];

$auth = new Auth($mysqli);

$auth->login($username, $password);

if ($auth->login()['error']) {

echo 'error:' . $auth->login()['message'];

} else {

echo 'success:' . $auth->login()['message'];

}

}

编辑:

如果我在类方法中分配变量,则代码可以工作:

public function login($username = 'user', $password = 'pass')

但如果我这样做,它将无法工作:

$username = 'User';

$password = 'pass';

$auth = new Auth($mysqli);

$auth->login($username, $password);

另外,如果我使用$auth-> login()之外的$_POST值,则会将它们分配,以便在将它们传递给类时它们不为空…

购物商城项目采用PHP+mysql有以及html+css jq以及layer.js datatables bootstorap等插件等开发,采用了MVC模式,建立一个完善的电商系统,通过不同用户的不同需求,进行相应的调配和处理,提高对购买用户进行配置….zip项目工程资源经过严格测试可直接运行成功且功能正常的情况才上传,可轻松复刻,拿到资料包后可轻松复现出一样的项目,本人系统开发经验充足(全领域),有任何使用问题欢迎随时与我联系,我会及时为您解惑,提供帮助。 【资源内容】:包含完整源码+工程文件+说明(如有)等。答辩评审平均分达到96分,放心下载使用!可轻松复现,设计报告也可借鉴此项目,该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的。 【提供帮助】:有任何使用问题欢迎随时与我联系,我会及时解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 下载后请首先打开README文件(如有),项目工程可直接复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值