所以我正在尝试为Web应用程序的数据库创建一个准备好的insert语句。对于注册系统,我使用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();
...
答案 0 :(得分:0)
您想要连接到sqlite数据库,但您有:
$db = new Database("bills.db");
你必须知道你必须有这样的东西:
$db = new PDO('sqlite:bills.db');
并且更改所有bindValue会将SQLITE3_TEXT
调用为PDO::PARAM_STR
,如下所示:
$stmt->bindValue(':adminemail', $admin_email, SQLITE3_TEXT);
为:
$stmt->bindValue(':adminemail', $admin_email, PDO::PARAM_STR);