2017-11-29 10 views
-2

PHPとphpmyadminを使ってシンプルなサインアップシステムを作った。しかし、入力にテキストを入力してsubmitを押すたびに、「構文解析エラー:構文エラー、予期しないエラーが発生しました({C:\ wamp64 \ www \ includes \ signup.inc」)。 php on line 15 " データベースに何も表示されていません。 (つまり、任意の関連性を持っている場合、私はWAMPサーバを使用するPS)PHPのシステムに説明できない構文エラー

サインアップPHPスクリプト(signup.inc.php)

<?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']); 
$username = mysqli_real_escape_string($conn, $_POST['username']); 
$password = mysqli_real_escape_string($conn, $_POST['password']); 

//Error handlers 
//Check for empty fields 
if (empty($first) || empty($last) || empty($email) || empty($username) || 
/*LINE 15 THE ERROR IS REFERRING TO*/ (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(); 
} 

データベース接続(dbh.inc.php)

<?php 

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

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

サインアップフォーム(PHPファイル内のhtml)(signup.php)

<?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="submit">Sign Up!</button><br> 
    </form> 
</div>    
</section> 

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

ヘルプははるかに高く評価されるだろう。ありがとう!

+0

への変更は、 '秒で('追加 'と同じだ(!preg_match' –

+2

はあなたに、構文エラーを示しAA適切なコードエディタを使用します、notepad ++ –

+1

問題を再現するのに十分なだけのものを含めることができれば助かります。[最小限で完全で検証可能な例を作成する方法](https://stackoverflow.com/help/mcve) –

答えて

0

これは単純なタイプミスです。そのため、if文には、)がありません。

あなたはコメントを追加しました、その行でこの

if (empty($first) || empty($last) || empty($email) || empty($username) || 
    empty($password)) { 
    header('Location: ../signup.php?signup=empty'); 
    exit(); 
} else { 
    ....