【问题标题】:Php Mysqli Undefined Functionphp Mysqli 未定义函数
【发布时间】:2013-01-05 01:04:11
【问题描述】:

执行时

mysqli_bind_result();

我收到一条错误消息“调用未定义的函数”。

我的代码如下:

$mysqli = new mysqli("localhost", "root", "", "*****");
if(isset($_POST['login'])){
    if($_POST['username']){
    if($_POST['password']){
    $username = $_POST['username'];
    $passwordtmp = $_POST['password'];
    $password = md5(md5($passwordtmp));
    //Connect to Database//
    if ($mysqli->connect_errno) {
            echo "Failed to connect to MySQL: (" . $mysqli->connect_errno . ") " . $mysqli->connect_error;
    }
    //Check if user exist in database//
    $query = mysqli_query($mysqli,"SELECT * FROM users WHERE username = '$username'");
    $numrows = mysqli_num_rows($query);
    if($numrows == 1){
        if($stmt = mysqli_prepare($mysqli, "SELECT password FROM users WHERE username = '$username'")){
            mysqli_execute($stmt);
                    mysqli_bind_result($stmt,$passw);
                    while(mysqli_stmt_fetch($stmt)){
                        $pass = $passw;  
                    }

附加信息:

  1. 我使用与我的 mysql 数据库的相同连接将此代码从另一台计算机传输到我的笔记本电脑。

        $mysqli = new mysqli("localhost", "root", "", "*****");
    
    1. 我将确切的数据库复制到我的笔记本电脑上,我的电脑和笔记本电脑都在使用 wamp。

    2. 我想知道这是否可能是与数据库的连接问题,或者只是编码错误。但它在我原来的电脑上完美运行,没有任何问题。

提前谢谢你。我会感谢有用的答案。

【问题讨论】:

  • 您对 SQL 注入敞开大门。请了解如何使用参数化查询(最好使用 PDO 模块)来保护您的 Web 应用程序。 bobby-tables.com/php.html 有一些示例可以帮助您入门。
  • 您正在混合使用 mysqli 的 OOP 使用和功能使用。虽然它可能会起作用,但您会从保持一致以帮助可读性和维护中受益。作为对@AndyLester 的评论 - mysqli 完全能够进行参数化查询,因此目前没有明显的理由切换到 PDO。
  • 我相信我正在这样做。我已经从另一个人那里接管了这段代码,并且正在切换

标签: php database phpmyadmin mysqli connection


【解决方案1】:

您可能正在使用 PHP > 5.4,因为函数 mysqli_bind_result 在 PHP 5.4 中已被删除。

将其更改为 mysqli_stmt_bind_result 应该可以解决您的问题。

mysqli_stmt_bind_result($stmt, $passw);

【讨论】:

    猜你喜欢
    • 2017-07-27
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2012-02-09
    • 1970-01-01
    • 2016-02-08
    • 2016-10-27
    • 1970-01-01
    相关资源
    最近更新 更多