我用 PHP 寫程式碼,遇到了一些錯誤,它也跳過了我的 else 語句
<?php // put your code here // $select_query = "Select * from `user_table` where username='$user_username'"; // $result = mysqli_query($con, $select_query); $sql = "Select * from `user_table` where username= ? "; // SQL with parameters $stmt = $con->prepare($sql); $stmt->bind_param("s", $user_username); $stmt->execute(); $result = $stmt->get_result(); $row_count = mysqli_num_rows($result); $row_data = mysqli_fetch_assoc($result); $user_ip = getIPAddress(); if ($_SESSION['attempt'] == 5) { $_SESSION['error'] = 'Attempt limit reach'; } else { if ($row_count > 0) { $_SESSION['username'] = $user_username; $row = mysqli_fetch_object($result); if (password_verify($user_password, $row_data['user_password'])) { // if ($row_count == 1 and $row_count_cart == 0) { // // echo"<script>alert('Login Successfully')</script>"; // echo"<script>window.open('profile.php','_self')</script>"; // } else { // $_SESSION['username'] = $user_username; // echo"<script>alert('Login Successfully')</script>"; // echo"<script>window.open('payment.php','_self')</script>"; // } if ($row->is_tfa_enabled) { $row->is_verified = false; $_SESSION["username"] = $row; $pin = rand(0, 9) . rand(0, 9) . rand(0, 9) . rand(0, 9) . rand(0, 9) . rand(0, 9); $sql = "UPDATE user_table SET pin = '$pin' WHERE user_id = '" . $row->user_id . "'"; mysqli_query($con, $sql); header("Location: enter_pin.php"); } else { $row->is_verified = true; $_SESSION["username"] = $row; header("Location: profile.php"); } } else { echo"<script>alert('Invalid Credentials(Password Incorrect) " .$number ." attempt left ') </script>"; $_SESSION['error'] = 'Password incorrect '; //this is where we put our 3 attempt limit $_SESSION['attempt'] += 1; //set the time to allow login if third attempt is reach if ($_SESSION['attempt'] == 5) { $_SESSION['attempt_again'] = time() + (1 * 60); //note 5*60 = 5mins, 60*60 = 1hr, to set to 2hrs change it to 2*60*60 } } } else { echo"<script>alert('Invalid Credentials')</script>"; } } } ?>
所以當我運行程式碼時它顯示 2 個錯誤,即
1)警告:嘗試在第 148 行的 C:xampphtdocsFinalYearProjectUsersuser_login.php 中讀取 null 屬性「is_tfa_enabled」
2)致命錯誤:未捕獲錯誤:嘗試在C:xampphtdocsFinalYearProjectUsersuser_login.php:170 中的null 上分配屬性“is_verified”:170 堆疊追蹤:#0 {main} 拋出在C: xampphtdocsFinalYearProjectUsersFinal_userF.行
當我將第 148 行更改為 $row_data['is_tfa_enabled'] 時,錯誤 1 將解決
表格中找不到
is_tfa_enabled
和is_verified
行 另外$row->is_verified = true;
不是有效的 commande 。您不能像這樣更改列值