php - 我对 php ://input function? 做错了什么

标签 php input

我目前的问题是我必须创建一个连接到 MySQL 数据库的后端 API。我的同学找到了一个关于如何创建一个的教程,但是它使用了一些我不熟悉的东西,我也找不到很多文档。

我想知道它究竟是如何工作的,我将包含教程中使用它的代码块。我希望你能帮助我。

到目前为止,我已经尝试使用谷歌搜索(没有实际结果)并询问我的老师,但他们似乎没有任何答案可以帮助我解决问题。据我发现,就读取/输出而言,它是一种 JSON 字符串。

从数据库中删除一行的函数,如您所见,它使用的似乎是 JSON API 调用。 (p.Categorie_ID)

  public function delete(){
        $query = "DELETE FROM categorie WHERE Categorie_ID= p.Categorie_ID";

        $stmt = $this->connection->prepare($query);

        $stmt->execute();

        return $stmt;
    }
$p  = array(
      "Object_ID" => $Object_ID,
      "Object_naam" => $Object_naam,
      "Object_merk" => $Object_merk,
      "Object_type" => $Object_type,
      "Object_status" => $Object_status,
      "Categorie_ID" => $Categorie_ID
    );
    array_push($Objects["body"], $p);
  }

上面我发布了我认为是原始代码块中的“p”变量。

<br />
<b>Notice</b>:  Trying to get property of non-object in <b>C:\xampp\htdocs\PHP\PHP API_Categories\entities\Categories\delete.php</b> on line <b>21</b><br />
object(Categories)#3 (4) {
  ["connection":"Categories":private]=>
  object(PDO)#1 (0) {
  }
  ["table_name":"Categories":private]=>
  string(10) "Categories"
  ["Categorie_ID"]=>
  NULL
  ["Categorie_naam"]=>
  NULL
}
NULL
{"message": "category was deleted."}

这是我运行/打开文件时输出的内容。它确实在删除时给出了消息;但是所有数据都返回为 NULL。我在这里忽略了什么?

我希望该函数删除提到的表(必须查看哪个表),但它在应该这样做时根本没有执行或返回任何内容。

(注意:如果您想阅读我最初尝试做的事情,可以在这里找到完整的源代码:https://www.techiediaries.com/php-rest-api/)

最佳答案

您正在正确地从 php://input 读取数据。问题出在您的 SQL 查询上。要从 $p 数组传递参数,您需要将参数插入查询并绑定(bind)数据。您还需要将数组作为参数发送给函数。

// this function takes in a parameter $p 
public function delete(string $Categorie_ID) {
    $query = "DELETE FROM categorie WHERE Categorie_ID = ?";
    $stmt = $this->connection->prepare($query);
    // Pass an element from $p to the execute function to replace the ? placeholder
    $stmt->execute([
        $Categorie_ID
    ]);

    // return $stmt; // there is nothing to return from delete action
}

然后您可以像这样调用该函数:

$yourObj->delete($p['Categorie_ID']); // pass the category from the array as an argument

关于php - 我对 php ://input function? 做错了什么,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56858686/

相关文章:

javascript - jQuery 可以检查输入内容是否改变了吗?

来自 onChange 的 JSF 操作

php - MySQL - 查询临时表以从表中检索 2 行

php - PHP源代码未在执行,它显示在呈现的页面上

php - magento 中各州的销售报告

php - 复杂分页与 NOT IN 条件 cakephp 2

python - 如何在 Python 中读取整数命令行参数?

javascript - 我不想发送空值

使用函数的 C++ 字符串输入

java - 谷歌搜索克隆错误