【问题标题】:Call to a member function bindValue() on a non-object [duplicate]在非对象上调用成员函数 bindValue() [重复]
【发布时间】:2015-05-13 05:20:41
【问题描述】:

所以我正在尝试为 Web 应用程序的数据库创建一个准备好的插入语句。对于注册系统,我使用 post 输入值,然后重定向到网页进行处理。但是,我不断收到错误“在第 18 行的 /path/to/file.php 中的非对象上调用成员函数 bindValue(),这是对 bindValue() 的第一次引用。代码是:

<?php

 session_start();

 require "database.php";
 $db = new Database("bills.db");

 $admin_password = $_POST['admin_password'];
 $admin_email = $_POST['admin'];
 $salt = sha1(time());
 $group_name = $_POST['group_name'];
 $group_password = $_POST['password'];

 $admin_hash = sha1($salt."--".$admin_password);
 $group_hash = sha1($salt."--".$group_password);

$stmt = $db->prepare("INSERT INTO billgroup VALUES (NULL, :adminemail, :adminpassword_hash, :groupname, :password_hash, :salt)");
$stmt->bindValue(':adminemail', $admin_email, SQLITE3_TEXT);
$stmt->bindValue(':adminpassword_hash', $admin_hash, SQLITE3_TEXT);
$stmt->bindValue(':groupname', $group_name, SQLITE3_TEXT);
$stmt->bindValue(':password_hash', $group_hash, SQLITE3_TEXT);
$stmt->bindValue(':salt', $salt, SQLITE3_TEXT);
$results = $stmt->execute();




 $stmt = $db->prepare("SELECT * FROM billgroup WHERE adminemail = :adminemail");
 $stmt->bindValue(':adminemail', $admin_email, SQLITE3_TEXT);
 $users = $stmt->execute();
 $user = $users->fetchArray();
...

【问题讨论】:

  • $admin_email 设置了吗?
  • 最好使用 redbeanphp 的家伙。它会处理一切
  • 是的,它从post中获取上一页文本框的值
  • 但是你检查过了吗?
  • 是的,刚刚检查过,正确的名称和正确的表单操作

标签: php sql database pdo bindvalue


【解决方案1】:

你想连接到一个 sqlite 数据库,但你有:

$db = new Database("bills.db");

你必须知道你必须有这样的东西:

$db = new PDO('sqlite:bills.db');

并更改所有 bindValue 调用 SQLITE3_TEXTPDO::PARAM_STR,如下所示:

$stmt->bindValue(':adminemail', $admin_email, SQLITE3_TEXT);

到:

$stmt->bindValue(':adminemail', $admin_email, PDO::PARAM_STR);

【讨论】:

  • 也许 Database 扩展 PDO... 或者环绕它。或者围绕一个 SQLite 类。谁知道Database里面是什么...!?
  • @Rudie 可以,但问题是因为$db不是PDO对象。
  • 你怎么知道的?如果Database extends PDO 它是一个 PDO 对象。不过你可能是对的。
猜你喜欢
  • 2014-12-19
  • 1970-01-01
  • 2011-05-28
  • 2014-06-05
  • 1970-01-01
  • 1970-01-01
  • 2010-09-08
相关资源
最近更新 更多