簡體   English   中英

用戶信息未發送到 MYSQL 數據庫

[英]User info not sent to MYSQL database

我正在嘗試制作:為網站創建帳戶頁面。 問題是沒有數據被發送到數據庫。

這是我放的:

include 'databaseconnection.php';
if (isset($_POST['submitbutton'])) {

  include 'databaseconnection.php';

  $first = mysqli_real_escape_string($conn, $_POST['first']);
  $last = mysqli_real_escape_string($conn, $_POST['last']);
  $password = mysqli_real_escape_string($conn, $_POST['password']);
  $email = mysqli_real_escape_string($conn, $_POST['email']);
  $username = mysqli_real_escape_string($conn, $_POST['username']);

  //error handlers
  // check for empty feilds

  if (empty($first) || empty($last) || empty($password) || empty($email) || empty($username)) {
      header("Location: signupcode.php");
      exit();
  } else {
      if (!preg_match("/ˆ[a-zA-Z]*$/",$first) || !preg_match("/ˆ[a-zA-Z]*$/",$last)) {
          header("Location: signupcode.php?signup=empty");
          exit();
      } else {
          //email check
          if (!filter_var($email, FILTER_VALIDATE_EMAIL)) {
              header("Location: signupcode.php?error");
              exit();
          } else {
              $sql = "SELECT * FROM users WHERE username='$username'";
              $result = mysqli_query($conn, $sql);
              $resultcheck = mysqli_num_rows($result);
              if ($resultcheck > 0) {
                  header("Location: signupcode.php?error");
                  exit();
              }  else {
                  $sql = "SELECT * FROM users WHERE email='$email'";
                  $result = mysqli_query($conn, $sql);
                  $resultcheck = mysqli_num_rows($result);
                  if ($resultcheck > 0) {
                      header("Location: signupcode.php?error");
                      exit();
                  } else {
                      //hashing the Password
                      $hasedpassword = password_hash($password, PASSWORD_DEFAULT);

                      $sql = "INSERT INTO users (username, firstname, lastname, password, email)
                            VALUES ('$username', '$first', '$last', '$hasedpassword', '$email');";
                      $dbservername= "localhost";
                      $dbusername= "root";
                      $dbpassword= "";
                      $dbname = "landingpage-login";

                      $conn = mysqli_connect($dbservername, $dbusername, $dbpassword, $dbname);

                      mysqli_query($conn, $sql);
                      header("Location: signupcode.php");
                      exit();
                 }
            }
        }
    }
  }

}

 ?>

問題是,當我將 go 轉到 localhost:8080/php 時,我的管理員在我的表中沒有顯示任何內容:數據庫中的用戶:landingpage-login。 每次我檢查它,它都是空的,用戶名,密碼等什么都沒有......

首先,任何編程語言都不能有多個else語句。 您的代碼到達第一個else並執行該塊。

嘗試擁有

 else if (!preg_match("/ˆ[a-zA-Z]*$/",$first) || !preg_match("/ˆ[a-zA-Z]*$/",$last)){//Code}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM