第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問(wèn)題,去搜搜看,總會(huì)有你想問(wèn)的

是否有必要在準(zhǔn)備語(yǔ)句中預(yù)先定義變量?

是否有必要在準(zhǔn)備語(yǔ)句中預(yù)先定義變量?

PHP
江戶(hù)川亂折騰 2023-07-08 22:01:23
我有以下準(zhǔn)備好的聲明:            $stmt = $conn->prepare("SELECT * FROM `users` WHERE user LIKE ? ");            $stmt->bind_param("s", $filtered_form['user']);            $stmt->execute();            $stmt->store_result();            if ($stmt->num_rows > 0) {               $stmt->bind_result($id, $user, $pass, $first, $last, $type, $email);               $stmt->fetch();               $stmt->close();            }            if ($pass === $filtered_form['pass']) {               $_SESSION['id'] = $id;               $_SESSION['user'] = $user;               $_SESSION['first'] = $first;               $_SESSION['last'] = $last;               $_SESSION['email'] = $email;               $_SESSION['type'] = $type;               header("Location:index.php");               exit;            } else {               return "Incorrect password";            }但是 Visual Studio 說(shuō)存在變量$id, $user, $pass, $first, $last, $type, $email未定義的問(wèn)題。我添加了這樣的變量:            $stmt = $conn->prepare("SELECT * FROM `users` WHERE user LIKE ? ");            $stmt->bind_param("s", $filtered_form['user']);            $stmt->execute();            $stmt->store_result();            if ($stmt->num_rows > 0) {               $id  = "";               $user = "";               $pass = "";               $first = "";               $last = "";               $type = "";               $email = "";               $stmt->bind_result($id, $user, $pass, $first, $last, $type, $email);               $stmt->fetch();               $stmt->close();            }然后問(wèn)題就消失了。在查看 PHP 文檔后,我找不到必須首先定義變量的示例,但 Visual Studio 仍然將其顯示為錯(cuò)誤。知道這是為什么嗎?
查看完整描述

1 回答

?
慕森卡

TA貢獻(xiàn)1806條經(jīng)驗(yàn) 獲得超8個(gè)贊

不,當(dāng)變量通過(guò)引用傳遞時(shí)沒(méi)有必要,這里就是這種情況。所以 Visual Studio 錯(cuò)了。


但是,您在這里使用的是過(guò)時(shí)的技術(shù),并且可以消除這些誤報(bào)警告并立即減少代碼量:


? ? ? ? $stmt = $conn->prepare("SELECT * FROM `users` WHERE user = ? ");

? ? ? ? $stmt->bind_param("s", $filtered_form['user']);

? ? ? ? $stmt->execute();

? ? ? ? $row = $stmt->get_result()->fetch_assoc();

? ? ? ? if ($row and password_verify($filtered_form['pass'], $row['pass']) {

? ? ? ? ? ?$_SESSION['user'] = $row;

? ? ? ? ? ?header("Location:index.php");

? ? ? ? ? ?exit;

? ? ? ? } else {

? ? ? ? ? ?return "Incorrect password";

? ? ? ? }

正如你所看到的,get_result()給你一個(gè)比 更好的結(jié)果(雙關(guān)語(yǔ)不是故意的)store_result(),讓你將用戶(hù)信息存儲(chǔ)在單個(gè)變量中,所以它不會(huì)亂七八糟的$_SESSION數(shù)組。


并被num_rows()證明是完全無(wú)用的(因?yàn)樗偸前l(fā)生)。


重要提示:您永遠(yuǎn)不應(yīng)該以純文本形式存儲(chǔ)密碼。始終支持哈希密碼。



查看完整回答
反對(duì) 回復(fù) 2023-07-08
  • 1 回答
  • 0 關(guān)注
  • 204 瀏覽

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢(xún)優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)