准备语句MySQLI: INSERT不工作


Prepared-statement MySQLI: INSERT doesn't work

我是一个编码初学者,无法解决这个错误。我试图创建一个登录/注册脚本,但我的INSERT语句不起作用,我找不到错误:/对不起,我的英语不好,我是德国人。

"致命错误:在布尔值上调用成员函数bind_param() "

  if (isset($_POST['registrieren']) && $_POST['name'] != "" && $_POST['password'] != "")
  {
    $url        = 'https://www.google.com/recaptcha/api/siteverify';
    $privateKey = "???????????????????????????";
    $response = file_get_contents($url . "?secret=" . $privateKey . "&response=" . $_POST['g-recaptcha-response'] . "&remoteip=" . $_SERVER['REMOTE_ADDR']);
    $data     = json_decode($response);
    if (isset($data->success) && $data->success == true)
    {
        $name            = $_POST['name'];
        $password        = $_POST['password'];
        $username_exists = $db->prepare("SELECT name from users WHERE name = ? ");
        $username_exists->bind_param('s', $name);
        $username_exists->execute();
        if ($username_exists->num_rows) {
            echo "<div class='fehler'>Name bereits vergeben!</div>";
        } else {
            $verschlüsseln = password_hash($password, PASSWORD_DEFAULT);
            $insert = $db->prepare("INSERT INTO users (name, password) VALUES (?, ?)");
            $insert->bind_param("ss", $name, $verschlüsseln);  
            $insert->execute();
            $_SESSION['name'] = $name;
            $_SESSION['password'] = $password;
            header("Location: http://localhost/data/login/me.php");
        }
    } else {
      echo "<div class='fehler'>Captcha-Check failed!</div>";
    }
}

错误提示prepare语句失败,但不清楚是哪一个。下面的代码没有经过测试,我想知道u上的重音是否会导致问题(?),所以我将该变量重命名为$hash

<?php
    if( !empty( $_POST['registrieren'] ) && !empty( $_POST['name'] ) && !empty( $_POST['password'] ) && !empty( $_POST['g-recaptcha-response'] ) ){
        $url        = 'https://www.google.com/recaptcha/api/siteverify';
        $privateKey = "6LdBNScTAAAAALrn5__S9lfV3EuSFu9Si_gwWeus";
        $response   = file_get_contents( $url . "?secret=" . $privateKey . "&response=" . $_POST['g-recaptcha-response'] . "&remoteip=" . $_SERVER['REMOTE_ADDR'] );
        $data       = json_decode( $response );

        if( isset( $data->success ) && $data->success == true ) {
            $name           = $_POST['name'];
            $password       = $_POST['password'];
            $stmt           = $db->prepare("SELECT `name` from `users` WHERE `name` = ?;");
            if( !$stmt ){
                exit('Error preparing sql select statement');
            }
            $stmt->bind_param( 's', $name );
            $stmt->execute();

            if ( $stmt->num_rows ) {
                echo "<div class='fehler'>Name bereits vergeben!</div>";
            } else {
                /* release results from previous cmd */
                $stmt->free_result();
                /* Is it possible that the accent on the 'u' caused problems? */
                $hash = password_hash( $password, PASSWORD_DEFAULT );
                $stmt = $db->prepare( "INSERT INTO `users` (`name`, `password`) VALUES (?, ?);" );
                if( !$stmt ){
                    exit('Error preparing sql insert statement');
                }
                $stmt->bind_param( "ss", $name, $hash );  
                $stmt->execute();
                /* again, free the results */
                $stmt->free_result();
                /* do you really want to store a password in a session variable? */
                $_SESSION['name'] = $name;
                $_SESSION['password'] = $password;

                header("Location: http://localhost/data/login/me.php");
            }
        } else {
            echo "<div class='fehler'>Captcha-Check failed!</div>";
        }
    }
?>