0

我正在尝试将用户访问令牌添加到我的数据库。我正在使用 php mysqlidb 连接库。

如果我在下面使用此功能,则会收到此错误:

<b>Warning</b>:  mysqli_stmt::bind_param(): Number of elements in type definition string doesn't match number of bind variables in MysqliDb.php</b> on line <b>1092</b>

function connectUser($id, $fbid, $accessToken) {
    global $db;
    $data = Array (
        'fbid' => $fbid,
        "access_token" => $accessToken
    );
    $db->where ('id', $id);
    $db->update ('users', $data);

}

我知道 accessToken 里面有东西,因为如果我在前面的函数中为 accessToken 添加回声,我会得到:

CadC5cqRAZArcBAKDZBZBA2AO5Beu1ZBWLFWl5FZClIuFvcx8jvdBZBTv3t3gplq32dm0gw99u62dQAAoBZC71bvgDYjy5RxnpjYzzUWoOlGmlZAwL4gtregzOF9mOqBtp24mybRVMR14mCmuA7YZAJ8kvxfonv151ZAadhlZCi1TKj8I5guOO2YZC2Vfs

然后尝试手动添加它没有错误:

 function connectUser($id, $fbid, $accessToken) {
        global $db;
        $data = Array (
            'fbid' => $fbid,
            "access_token" => 'CadC5cqRAZArcBAKDZBZBA2AO5Beu1ZBWLFWl5FZClIuFvcx8jvdBZBTv3t3gplq32dm0gw99u62dQAAoBZC71bvgDYjy5RxnpjYzzUWoOlGmlZAwL4gtregzOF9mOqBtp24mybRVMR14mCmuA7YZAJ8kvxfonv151ZAadhlZCi1TKj8I5guOO2YZC2Vfs'
        );
        $db->where ('id', $id);
        $db->update ('users', $data);

    }

这里发生了什么?

4

1 回答 1

0

此警告意味着您的输入参数之一 $id、$fbid 或 $accessToken 为空。将它们记录在某个地方,您会看到。

于 2015-12-14T09:08:11.053 回答