@Lavrov95

Email и password не добавляюца в db. Кто может подсказать что не так?

var_dump($password); выводит string(0) ""
var_dump($email); выводит bool(false);

Database.php

<?php

class Database
{
    private $hostdb = "localhost";
    private $userdb = "root";
    private $passworddb = "";
    private $namedb = "color-school";
    public $pdo;

    public function __construct()
    {
        if (!isset($this->pdo)) {
            try {
                $link = new PDO("mysql:host=" . $this->hostdb . ";dbname=" . $this->namedb, $this->userdb, $this->passworddb);
                $link->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
                $link->exec("SET CHARACTER SET utf8");
                $this->pdo = $link;
            } catch (PDOException $e) {
                die("Fail to connect with Database " . $e->getMessage());
            }
        }
    }
}

register.php
<?php
include 'includes/header.php';
include 'library/User.php';
?>
<?php
$user = new User();
if($_SERVER['REQUEST_METHOD']=='POST' && isset($_POST['register'])){
    $userRegistration = $user->userRegistration($_POST);
}
?>
    <div class="panel panel-default">
        <div class="panel-heading">
            <h2>User Registration</h2>
        </div>
        <div class="panel-body">
            <div style="max-width: 600px; margin: 0 auto">
                <?php
                if(isset($userRegistration)){
                    echo $userRegistration;
                }
                ?>
                <form action="" method="post">
                    <div class="form-group">
                        <label for="name">Name</label>
                        <input type="text" id="name" name="name" class="form-control">
                    </div>

                    <div class="form-group">
                        <label for="username">Username</label>
                        <input type="text" id="username" name="username" class="form-control">
                    </div>

                    <div class="form-group">
                        <label for="email">Email Address</label>
                        <input type="text" id="email" name="email" class="form-control">
                    </div>

                    <div class="form-group">
                        <label for="password">Password</label>
                        <input type="password" id="password" name="password" class="form-control">
                    </div>
                    <button type="submit" name="register" class="btn btn-success">Submit</button>
                </form>
            </div>
        </div>
    </div>
<?php include 'includes/footer.php' ?>

User,php
<?php
include_once 'Session.php';
include 'Database.php';

class User
{
    private $db;

    public function __construct()
    {
        $this->db = new Database();
    }

    public function userRegistration($data)
    {
        $name = $data['name'];
        $username = $data['username'];
        $email = $data['email'];
        $password = md5($data['password']);
        $chk_email = $this->emailCheck($email);


        if ($name == "" || $username == "" || $email = "" || $password = "") {
            $message = "<div class='alert alert-danger'><strong>Error! </strong>Field must not be empty</div>";
            return $message;
        }

        if (strlen($username) < 3) {
            $message = "<div class='alert alert-danger'><strong>Error! </strong>User name is to short!</div>";
            return $message;
        } elseif (preg_match('/[^a-z0-9_-]+/i', $username)) {
            $message = "<div class='alert alert-danger'><strong>Error! </strong>Username must only contain alphanumerical, dashes and underscores!</div>";
            return $message;
        }

        if ($chk_email == true) {
            $message = "<div class='alert alert-danger'><strong>Error! </strong>The email address already exist!</div>";
            return $message;
        }
        var_dump($email);

        $sql = "INSERT INTO users(name, username, email, password) VALUES(:name, :username, :email, :password)";
        $query = $this->db->pdo->prepare($sql);
        $query->bindValue(':name', $name);
        $query->bindValue(':username', $username);
        $query->bindValue(':email', $email);
        $query->bindValue(':password', $password);
        $result = $query->execute();
        if ($result) {
            $message = "<div class='alert alert-success'><strong>Success! </strong>Thank you, you have been registered.</div>";
            return $message;
        } else {
            $message = "<div class='alert alert-danger'><strong>Error! </strong>Sorry, there has been problem inserting your details.</div>";
            return $message;
        }
    }

    public function emailCheck($email)
    {
        $sql = "SELECT email FROM users WHERE email = :email";
        $query = $this->db->pdo->prepare($sql);
        $query->bindValue(':email', $email);
        $query->execute();
        if ($query->rowCount() > 0) {
            return true;
        } else {
            return false;
        }
    }

}
  • Вопрос задан
  • 369 просмотров
Решения вопроса 1
Adamos
@Adamos
$password = md5($data['password']);
if ($password = "")

Этот if НИКОГДА не сработает.
Причем по двум причинам. Вторая - одинарное = вместо двойного == (встречается в коде несколько раз).
Ответ написан
Пригласить эксперта
Ответы на вопрос 1
ThunderCat
@ThunderCat Куратор тега PHP
{PHP, MySql, HTML, JS, CSS} developer
то есть проверить что приходит в пост религия не позволяет? Неужели не проще каскадно проверить где увас теряются данные чем эту простыню сюда фигачить?
PS: Каша из объектов и хтмл смотрится как ржавая пила для распила дерева в лаборатории по производству процессоров. Сюрреалистично )
Ответ написан
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы