• 技术文章 >后端开发 >php教程

    异常提示:Fatal error: Call to undefined function mysqli_num_row()

    2016-06-13 11:53:59原创921

    错误提示:Fatal error: Call to undefined function mysqli_num_row()
    错误提示就如标题所示,网上也找了一圈,差不多都是说没有开启php_mysqli模块,我的wampserver环境本身已经开启,但是我还是去重新关闭在开启,结果都是一样,有一点很奇怪,网上一般都是在链接数据库的时候失败,但是我链接数据库没有提示失败,而是在使用mysqli_num_row时候出现错误

    下面先上下我在查看phpinfo下mysqli下的开启情况
    mysqli
    MysqlI Support enabled
    Client API library version mysqlnd 5.0.8-dev - 20102224 - $Id: 65fe78e70ce53d27a6cd578597722950e490b0d0 $
    Active Persistent Links 0
    Inactive Persistent Links 0
    Active Links 0

    Directive Local Value Master Value
    mysqli.allow_local_infile On On
    mysqli.allow_persistent On On
    mysqli.default_host no value no value
    mysqli.default_port 3306 3306
    mysqli.default_pw no value no value
    mysqli.default_socket no value no value
    mysqli.default_user no value no value
    mysqli.max_links Unlimited Unlimited
    mysqli.max_persistent Unlimited Unlimited
    mysqli.reconnect Off Off


    下面是我的代码部分
    require ('inc/config.php');
    $page_title = '注册-CNode博客';
    include ('inc/header.php');
    if ($_SERVER['REQUEST_METHOD'] == 'POST') {
    require (MYSQL);
    $trimmed = array_map('trim', $_POST);
    $errors = array();
    if ($_POST['code'] != $_SESSION['code']) {
    $errors[] = '验证码不正确!';
    }
    if(empty($trimmed['username'])) {
    $errors[] = '用户名不能为空';
    } else {
    if (preg_match ('/^[A-Z \'.-]{5,20}$/i', $trimmed['username'])) {
    $un = mysqli_real_escape_string ($conn, $trimmed['username']);
    } else {
    $errors[] = '您的用户名格式不对';
    }
    }

    if(empty($trimmed['email'])) {
    $errors[] = '电子邮件地址不能为空';
    } else {
    if (filter_var($trimmed['email'], FILTER_VALIDATE_EMAIL)) {
    $e = mysqli_real_escape_string ($conn, $trimmed['email']);
    } else {
    $errors[] = '您的电子邮件地址格式不对';
    }
    }

    if(!empty($trimmed['password'])) {
    if (preg_match ('/^\w{4,20}$/', $trimmed['password']) ) {
    if ($trimmed['password'] == $trimmed['notpassword']) {
    $p = mysqli_real_escape_string ($conn, $trimmed['password']);
    } else {
    $errors[] = '登录密码和确认密码不一致';
    }
    } else {
    $errors[] = '请输入有效的登录密码';
    }
    } else {
    $errors[] = '登录密码不能为空';
    }
    if(empty($trimmed['notpassword'])) {
    $errors[] = '确认密码不能为空';
    }

    if (empty($errors)) {
    // 确定电子邮件是否被使用
    $q = "SELECT user_id FROM users WHERE email='$e'";
    $r = mysqli_query ($conn, $q) or trigger_error("Query: $q\n
    MySQL Error: " . mysqli_error($conn));
    if (mysqli_num_row($r) == 0) { // 如果查询验证电子邮件地址未被使用,则注册用户
    $a = md5(uniqid(rand(), true)); // 创建一个激活码(创建一个长度正好为32个字符的字符串)
    $q = "INSERT INTO users (username, email, password, active, registration_date) VALUES ('$un', '$e', SHA1('$p'), '$a', NOW() )";
    $r = mysqli_query ($conn, $q) or trigger_error("Query: $q\n
    MySQL Error: " . mysqli_error($conn));
    if (mysqli_affected_rows($conn) == 1) {
    $body = "感谢您的注册,激活您的帐户,请点击这里:\n\n";
    $body .= BASE_URL . 'activate.php?x=' . urlencode($e) . "&y=$a";
    mail($trimmed['email'], '确认注册', $body, 'From: [email protected]');
    echo '

    感谢您的注册!一封确认邮件已经发送到您的邮箱。请在该电子邮件中单击链接,以激活您的帐户。

    ';
    exit();
    } else {
    echo '

    用户注册失败,为此我们表示抱歉,请在注册一次

    ';
    }
    } else { // 查询验证出来的电子邮件地址已经被注册
    echo '

    电子邮件地址已经被注册

    ';
    }
    } else {
    foreach ($errors as $msg) { // Print each error.
    echo " - $msg
    \n";
    }
    }
    mysqli_close($conn);
    }
    ?>

    相关文章推荐

    • 手写PHP API框架(二)之Composer的安装使用• 聊聊php怎么让Swoole/Pool进程池实现Redis持久连接• 手写PHP API框架(一)之PSR规范• 聊聊PHP escapeshellarg函数使用的中文问题• PHP原生类的总结分享
    1/1

    PHP中文网