讓我開始說我對此非常陌生。我正在嘗試開發一款沒有真實體驗的移動應用和網站。有可能是我錯過了或我做錯了,但我似乎無法指出問題在哪裏。在創建我自己的之前,我遵循了一個視頻指南(演示文件下載到我的電腦),但似乎無法連接到我的數據庫。我也複製了這些演示文件,並將它們放入我的代碼中,但它仍然讓我陷入了一個部分。我正在使用程序MAMP進行連接,並使用Brackets作爲代碼。下面是我的會議文件:通過PHP連接mySQL db
數據庫連接 -
<?php
$dbServername = "localhost";
$dbUsername = "root";
$dbPassword = "root";
$dbName = "Login System";
$con = mysqli_connect($dbServername, $dbUsername, $dbPassword, $dbName);
我的註冊文件 -
<?php
if (isset($_POST['submit'])) {
include_once 'dbh.inc.php';
$first = mysqli_real_escape_string($conn, $_POST['first']);
$last = mysqli_real_escape_string($conn, $_POST['last']);
$email = mysqli_real_escape_string($conn, $_POST['email']);
$uid = mysqli_real_escape_string($conn, $_POST['uid']);
$pwd = mysqli_real_escape_string($conn, $_POST['pwd']);
//Error handlers
//Check for empty fields
if (empty($first) || empty($last) || empty($email) || empty($uid) || empty($pwd)) {
echo <h2>Please fill in all fields;
exit();
} else {
//Check if input characters are valid
if (!preg_match("/^[a-zA-Z]*$/", $first) || !preg_match("/^[a-zA-Z]*$/", $last)) {
header("Location: ../signup.php?signup=invalid");
exit();
} else {
//Check if email is valid
if (!filter_var($email, FILTER_VALIDATE_EMAIL)) {
header("Location: ../signup.php?signup=email");
exit();
} else {
$sql = "SELECT * FROM users WHERE user_uid='$uid'";
$result = mysqli_query($conn, $sql);
$resultCheck = mysqli_num_rows($result);
if ($resultCheck > 0) {
header("Location: ../signup.php?signup=usertaken");
exit();
} else {
//Hashing the password
$hashedPwd = password_hash($pwd, PASSWORD_DEFAULT);
//Insert the user into the database
$sql = "INSERT INTO users (first, last, email, uid, pwd) VALUES ('$first', '$last', '$email', '$uid', '$hashedPwd');";
mysqli_query($conn, $sql);
header("Location: ../signup.php?signup=success");
exit();
}
}
}
}
} else {
header("Location: ../signup.php");
exit();
}
?>
我的登錄表
<?php
include_once 'header.php';
?>
<section class="main-container">
<div class="main-wrapper">
<h2>Signup</h2>
<form class="signup-form" action="includes/signup.inc.php" method="POST">
<input type="text" name="first" placeholder="Firstname">
<input type="text" name="last" placeholder="Lastname">
<input type="text" name="email" placeholder="E-mail">
<input type="text" name="uid" placeholder="Username">
<input type="password" name="pwd" placeholder="Password">
<Button type="submit" name="submit">Sign up</Button>
</form>
</div>
</section>
<?php
include_once 'footer.php';
?>
我已將「root」密碼重置爲「root」,並確保可以使用該密碼登錄。如果任何字段爲空,則檢查錯誤列表的文檔返回到URL中帶有「= empty」字樣的前一頁。無論我在我的字段中輸入什麼信息,它都不會將信息推送到數據庫中,或者我錯誤地映射了我的字段,因此其中一個數據庫字段爲空。
任何幫助將不勝感激。正如我在本文開頭所說的那樣,我對此非常陌生。你可能會看到一些令人難以置信的明顯而有些愚蠢的東西......你被警告過!我正在創建一個允許用戶登錄的移動應用程序和網站。登錄嘗試將引用我的本地主機數據庫,以確認用戶不存在或用戶未使用。
謝謝!
:也許variabl e不匹配?我在你的數據庫連接中看到'$ con',但是當試圖用於轉義函數和查詢時,有'$ conn'(一個額外的'n')。 –
我很感謝你看看。我確實用$ conn嘗試過,但這也不起作用。我用$ con進行了測試,但沒有奏效,但我忘了將它改回來。 – Palmeeze
你確定連接成功嗎?讓程序幫助你發現什麼是錯的。嘗試在連接後(或包含行後)添加以下內容:'if(!$ conn){echo'沒有連接:'。 mysqli_connect_error(); }'...確保首先將'$ con'改回到'$ conn'。 –