2017-11-29 21 views
0

맞춤법 오류를 확인 했는데도 문제가없는 것처럼 보이지만 내 php 가입 시스템이 로컬로 호스팅 된 phpmyadmin 데이터베이스에 연결되지 않습니다. 헤더는 PHP 가입 스크립트에 명시되어 있더라도 변경되지 않습니다. 아무것도 데이터베이스로 전송되지 않습니다 (오류가 없습니다). 누군가 내가 뭘 잘못하고 있는지 말할 수 있다면 좋을 것입니다.PHP 가입 시스템이 작동하지 않습니다. (phpmyadmin, wampserver)

가입 오류 처리기 (PS의 footer.php 및 header.php 올바른 양식에 포함) 및 스크립트 가입 :

<?php 

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

include_once 'dbh.inc.php'; 

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

//Error handlers 
//Check for empty fields 
if (empty($first)) || (empty($last)) || (empty($email)) || 
(empty($username)) || (empty($password)) { 
    header("Location: ../signup.php?signup=empty"); 
    exit(); 
} else { 
    //Check is 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=empty"); 
      exit(); 
     } else { 
      $sql = "SELECT * FROM users WHERE user_username='username'"; 
      $result = mysqli_query($conn, $sql); 
      $resultCheck = mysqli_num_rows($result); 

      if ($resultCheck > 0) { 
       header("Location: ../signup.php?signup=usertaken"); 
       exit(); 
      } else { 
       //Hashing the password 
       $hashedPassword = password_hash($password, 
PASSWORD_DEFAULT); 
       //Insert the user into the database 
       $sql = "INSERT INTO users (user_first, user_last, 
user_email, user_username, user_password) VALUES ('$first', '$last', 
'$email', '$username' '$hashedPassword');"; 
       mysqli_query($conn, $sql); 
       header("Location: ../signup.php?signup=success"); 
       exit(); 
      } 
     } 
    } 
} 

} else { 
header("Location: ../signup.php"); 
exit(); 
} 

데이터베이스 연결 :

<?php 

$dbServername = "localhost"; 
$dbUsername = "root"; 
$dbPassword = ""; 
$dbServername = "loginsystem"; 

$conn = mysqli_connect($dbServername, $dbUsername, $dbPassword, 
$dbServername); 

가입 양식을 (HTML 파일) :

<?php include_once 'header.php';?> 

<section class="main-container"> 
<div class="wrapper"> 
    <h2>Sign Up</h2> 
    <form class="Sign" action="includes/signup.inc.php" method="POST"> 
     <input type="text" name="first" placeholder="First Name"><br> 
     <input type="text" name="last" placeholder="Last Name"><br> 
     <input type="email" name="email" placeholder="E-mail"><br> 
     <input type="text" name="username" placeholder="Username"><br> 
     <input type="password" name="password" placeholder="Password"><br> 
     <button type="submit" name="">Sign Up!</button><br> 
    </form> 
</div>    
</section> 

<?php include_once 'footer.php';?> 

가능한 경우 도움을 받으십시오. 대단히 감사하겠습니다. 감사!

+2

'submit'이라는 버튼이 없으므로 $ _POST [ 'submit']'이 (가) 설정되지 않습니다. – Jeff

+2

첫 번째'if' 안에 들어가는 지 확인/확인 했습니까? – Jeff

+4

+'mysqli_real_escape_string ($ conn, $ _POST) $ _ POST [ 'first'];'와'user_username = 'username'과 SQL 인젝션을 찾는 SELECT 쿼리를 포함한 많은 다른 이슈들. 당신이 그것을 묻지 않으면 그것은 또한 오류를 보여주지 않을 것입니다. –

답변

0

이름 당신의 HTML 가입 페이지의 버튼을 제출 '제출'보내기

<button type="submit" name="submit">Sign Up!</button> 

변경 PHP 가입 페이지 POST를 :

:

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

변경 빈 값에 STMT의 확인을

if ((empty($first)) || (empty($last)) or (empty($email)) || (empty($username)) || (empty($password))) 

stmt가 다음과 같은지 확인하는 입력 문자 유효성을 변경하십시오.

if ((!preg_match("/^[a-zA-Z]*$/", $first)) || ((!preg_match("/^[a-zA-Z]*$/", $last))))