Cannot insert into database using web service

I have a problem when I try to insert something into my database using my web service. I have it:

index.php

<div class="modal-body">
                  <form id="wineForm">

                        <label>Id Selecao:</label>
                        <input type="text" id="id_selecao" name="id_selecao"/>

                        <label>Nome:</label>
                        <input type="text" id="nome" name="nome"/>

                        <label>Idade:</label>
                        <input type="text" id="idade" name="idade"/>

                        <label>Clube:</label>
                        <input type="text" id="clube" name="clube"/>
                  </form>
                </div>

                <div class="modal-footer">
                  <button type="button" class="btn btn-default" data-dismiss="modal">Close</button>
                  <button id="btnAdd" type="button" class="btn btn-primary">Add</button>
                </div>

...

 <script type="text/javascript">
    var rootURLPessoas = "http://localhost/aw014/webservice/services/pessoas";

    function addPessoa() {
            console.log('addPessoa aquiiiiiiii');
            $.ajax({
                type: 'POST',
                contentType: 'application/json',
                url: rootURLPessoas + '/add',
                dataType: "json",
                data: formToJSON(),
                success: function(data, textStatus, jqXHR){
                        alert('Person created successfully');
                        console.log("dsdkasdajhdjkas", data.id_selecao);
                        //$('#wineId').val(data.id);
                },
                error: function(jqXHR, textStatus, errorThrown){
                    alert('addWine error: ' + textStatus);
                }
            });
        }

    function formToJSON() {
    return JSON.stringify({

        "id_selecao": $('#id_selecao').val(), 
        "nome": $('#nome').val(), 
        "idade": $('#idade').val(),
        "clube": $('#clube').val(),
        "posicao": $('#posicao').val()
        });
    }


    jQuery(document).ready(function ($) {
            $('#tabs').tab();

        $('#btnAdd').click(function() {
           addPessoa();
        });
    });

    </script>

service.php

function addPessoa(){
    $request = \Slim\Slim::getInstance()->request();
    $pessoa = json_decode($request->getBody());
    $sql = "INSERT INTO pessoa (id_selecao, nome, idade,clube, posicao) values (:id_selecao, :nome,:idade,:clube,:posicao) ";
    $conn = getConn();
    $stmt = $conn->prepare($sql);
    $stmt->bindParam("id_selecao",$pessoa->id_selecao);
    $stmt->bindParam("nome",$pessoa->nome);
    $stmt->bindParam("idade",$pessoa->idade);
    $stmt->bindParam("clube",$pessoa->clube);
    $stmt->bindParam("posicao",$pessoa->posicao);
    $stmt->execute();
    $pessoa->id = $conn->lastInsertId();
    $conn= null;
    echo json_encode($pessoa);
}

So, when I fill out all the fields and click the "Add" button, give me an alert Person created successfully. But when I check the database, nothing was inserted and I don’t know why.

+4
source share
1 answer

When you go to the success function, which only means that the php script was successfully executed / without any fatal errors.

json, script.

console.log(data); , . , , script .

script ini_set('display_errors',1);, , json ( ), , , PDO .

+3

Source: https://habr.com/ru/post/1542107/


All Articles