Получение http_response_code (404) при попытке динамически передать идентификатор записи в phpmyadmin. Я пытаюсь интегрировать MySQL предварительно с Salesforce - PullRequest
1 голос
/ 22 апреля 2020

Я пытаюсь обновить одну конкретную запись или строку, соответствующую идентификатору, переданному динамически. Существует запись, принадлежащая этому идентификатору. Когда я даю URL, за которым следует «? Id = 3», я получаю сообщение об ошибке 404, в котором говорится, что такой записи не существует. Хотелось бы узнать, какую ошибку я совершил. Ниже мой код.

<?php
header("Access-Control-Allow-Origin: *");
header("Content-Type: application/json; charset=UTF-8");
header("Access-Control-Allow-Methods: POST");
header("Access-Control-Max-Age: 3600");
header("Access-Control-Allow-Headers: Content-Type, Access-Control-Allow-Headers, Authorization, X-Requested-With");

include_once '../config/database.php';
include_once '../objects/constitute.php';

$database = new Database();
$db = $database->getConnection();
$constitute = new Constitute($db);

$data = json_decode(file_get_contents("php://input"));
$constitute->id = isset($_GET['id']) ? $_GET['id'] : die();
$constitute->name = $data->name;
$constitute->address = $data->address;
$constitute->constitution_type = $data->constitution_type;
$constitute->organisation_id = $data->organisation_id;

if($constitute->update()){
    http_response_code(200);
    echo json_encode(array("message" => "Constitute was updated."));
}
 else{
    http_response_code(503);
    echo json_encode(array("message" => "Unable to update constitute."));
}
?>

Ниже приведен метод update ():

    function update(){
    $query = "UPDATE
                " . $this->table_name . "
            SET
                name = :name,
                address = :address,
                constitution_type = :constitution_type,
                organisation_id = :organisation_id
            WHERE
                id = ?";
    $stmt = $this->conn->prepare($query);

    $this->id=htmlspecialchars(strip_tags($this->id));
    $this->name=htmlspecialchars(strip_tags($this->name));
    $this->address=htmlspecialchars(strip_tags($this->address));
    $this->constitution_type=htmlspecialchars(strip_tags($this->constitution_type));
    $this->organisation_id=htmlspecialchars(strip_tags($this->organisation_id));

    $stmt->bindParam(':id', $this->id);
    $stmt->bindParam(':name', $this->name);
    $stmt->bindParam(':address', $this->address);
    $stmt->bindParam(':constitution_type', $this->constitution_type);
    $stmt->bindParam(':organisation_id', $this->organisation_id);

    if($stmt->execute()){
        return true;
    }
    return false;
}

Также, когда я пытаюсь передать обновленную запись в почтальоне, я получаю код успеха. Но запись не сохраняется. Пожалуйста, дайте мне знать, где я сделал ошибки.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...