Ir para conteúdo
ZotInfoCorp

json encode retornando valor nulo em uma situação e em outra os valores certos

Recommended Posts

Bom dia pessoal, estou quase concluindo um aplicativo, porém estou empacado nessa situação.
Fiz um sistema simples de registro e login apenas pra guardar valores do celular no mysql, ele guarda todos os valores certinhos, também fiz um sistema simples de ranking usando Android, MySql e PHP, ele retorna tudo perfeito.
Porém quando eu tento fazer o login comparando o usuario e senha do banco de dados pelo android, ele me retorna como valor nulo, sendo que se eu editar o php com usuario e senha, ele retorna no browser os dados referente ao usuário, alguém saberia o por que?

Sistema de Registrar:   

public void registrarConta(View v) {
        final String nome = profilename.getText().toString();
        final String senha = profilepass.getText().toString();
        final String email = profileemail.getText().toString();
        String id = profileid.getText().toString();

        String url = HOST + "/criartapball.php";


        if(nome.isEmpty()) {
            profilename.setError("Digite seu Nome!");
        } //else if()
        else if(senha.isEmpty()) {
            profilepass.setError("Digite uma Senha!");
        } else if(email.isEmpty()) {
            profileemail.setError("Digite seu Email!");
        } else if(id.isEmpty()) {
            final Future<JsonObject> jsonObjectFuture = Ion.with(registrar.this)
                    .load(url)
                    .setBodyParameter("NOME", nome)
                    .setBodyParameter("SENHA", senha)
                    .setBodyParameter("EMAIL", email)
                    .setBodyParameter("DINHEIRO", "0")
                    .setBodyParameter("RECORDE", "0")
                    .setBodyParameter("CLIQUES", "0")
                    .setBodyParameter("MAIOR_NIVEL", "0")
                    .setBodyParameter("TOTAL_GANHO", "0")
                    .setBodyParameter("REGISTRADO", "1")
                    .asJsonObject()
                    .setCallback(new FutureCallback<JsonObject>() {
                        @Override
                        public void onCompleted(Exception e, JsonObject result) {

                            if(result == null) {
                                Toast.makeText(registrar.this, "Não foi possível! Verifique sua conexão.", Toast.LENGTH_LONG).show();
                            } else {
                                if (result.get("CREATE").getAsString().equals("OK")) {

                                    int idRetornado = Integer.parseInt(result.get("ID").getAsString());

                                    //-------- SISTEMA DE DADOS OFFLINE SALVOS NO CELULAR
                                    SharedPreferences settings = getSharedPreferences("GAME_DATA", Context.MODE_PRIVATE);
                                    SharedPreferences.Editor editor = settings.edit();

                                    editor.putInt("TOTAL_GANHO", 0);
                                    editor.putInt("DINHEIRO_ATUAL", 0);
                                    editor.putInt("CLIQUES_FEITOS", 0);
                                    editor.putInt("HIGH_SCORE", 0);
                                    editor.putInt("MAIOR_LEVEL", 0);
                                    editor.putString("NOME", nome);
                                    editor.putString("SENHA", senha);
                                    editor.putString("EMAIL", email);
                                    editor.putInt("REGISTRADO", 1);
                                    editor.putInt("ID_REGISTRO", idRetornado);
                                    editor.commit();

                                    Toast.makeText(registrar.this, "Jogador " + nome + " criado com Sucesso! ID: " + idRetornado, Toast.LENGTH_LONG).show();
                                    Log.d(TAG, "Usuário Registrado:>>> " + nome + " - ID: " + idRetornado + " <<<");
                                    startActivity(new Intent(getApplicationContext(), start.class));

                                } else {
                                    Toast.makeText(registrar.this, "Nome já utilizado!", Toast.LENGTH_LONG).show();
                                }
                            }
                        }
                    });
        }
    }

PHP do registro:

   

<?php 
    include "conexaotapball.php";
    
    $nome = $_POST['NOME'];
    $senha = $_POST['SENHA'];
    $email = $_POST['EMAIL'];
    $dinheiro = $_POST['DINHEIRO'];
    $record = $_POST['RECORDE'];
    $cliques = $_POST['CLIQUES'];
    $maior_nivel = $_POST['MAIOR_NIVEL'];
    $total_ganho = $_POST['TOTAL_GANHO'];
    $registrado = $_POST['REGISTRADO'];
    
    $sql_insert = "INSERT INTO jogadores (NOME, SENHA, EMAIL, DINHEIRO, RECORDE, CLIQUES, MAIOR_NIVEL, TOTAL_GANHO, REGISTRADO) VALUES (:NOME, :SENHA, :EMAIL, :DINHEIRO, :RECORDE, :CLIQUES, :MAIOR_NIVEL, :TOTAL_GANHO, :REGISTRADO)";
    
    $stmt = $PDO->prepare($sql_insert);
    
    $stmt->bindParam(':NOME',$nome);
    $stmt->bindParam(':SENHA',$senha);
    $stmt->bindParam(':EMAIL',$email);
    $stmt->bindParam(':DINHEIRO',$dinheiro);
    $stmt->bindParam(':RECORDE',$record);
    $stmt->bindParam(':CLIQUES',$cliques);
    $stmt->bindParam(':MAIOR_NIVEL',$maior_nivel);
    $stmt->bindParam(':TOTAL_GANHO',$total_ganho);
    $stmt->bindParam(':REGISTRADO',$registrado);
    
    if($stmt->execute()) {
        $id = $PDO->lastInsertId();
        $dados = array("CREATE"=>"OK", "ID"=>$id);
    } else {
        $dados = array("CREATE"=>"ERRO");
        //echo $dados->getMessage();
    }
    echo json_encode($dados);
?>

Sistema de Logar:   

public void logarConta(View v) {
        final String nome = profilename.getText().toString();
        final String senha = profilepass.getText().toString();

        final String url = HOST + "/login.php";


        if(nome.isEmpty()) {
            profilename.setError("Digite seu Nome!");
        }
        else if(senha.isEmpty()) {
            profilepass.setError("Digite sua Senha!");
        } else {
            final Future<JsonObject> jsonObjectFuture = Ion.with(logar.this)
                    .load(url)
                    .setBodyParameter("NOME", nome)
                    .setBodyParameter("SENHA", senha)
                    .asJsonObject()
                    .setCallback(new FutureCallback<JsonObject>() {
                        @Override
                        public void onCompleted(Exception e, JsonObject result) {
                            //atualizarDados();

                            if(result == null) {
                                Toast.makeText(logar.this, "Não foi possível! Verifique sua conexão.", Toast.LENGTH_LONG).show();
                            } else {
                                if (result.get("LOGAR").getAsString().equals("OK")) {

                                    JsonObject obj = result.get(result.get("ID").getAsString()).getAsJsonObject();

                                    rankingrecorde r = new rankingrecorde();
                                    r.setID(Integer.valueOf(obj.get("ID").getAsString()));
                                    r.setNome(obj.get("NOME").getAsString());
                                    r.setSenha(obj.get("SENHA").getAsString());
                                    r.setEmail(obj.get("EMAIL").getAsString());
                                    r.setDinheiro(obj.get("DINHEIRO").getAsString());
                                    r.setRecord(obj.get("RECORDE").getAsString());
                                    r.setTotal_ganho(obj.get("TOTAL_GANHO").getAsString());
                                    r.setMaior_nivel(obj.get("MAIOR_NIVEL").getAsString());
                                    r.setCliques(obj.get("CLIQUES").getAsString());
                                    r.setRegistrado(obj.get("REGISTRADO").getAsString());

                                    //-------- SISTEMA DE DADOS OFFLINE SALVOS NO CELULAR
                                    SharedPreferences settings = getSharedPreferences("GAME_DATA", Context.MODE_PRIVATE);
                                    SharedPreferences.Editor editor = settings.edit();

                                    editor.putInt("TOTAL_GANHO", Integer.valueOf(r.getTotal_ganho()));
                                    editor.putInt("DINHEIRO_ATUAL", Integer.valueOf(r.getDinheiro()));
                                    editor.putInt("CLIQUES_FEITOS", Integer.valueOf(r.getCliques()));
                                    editor.putInt("HIGH_SCORE", Integer.valueOf(r.getRecord()));
                                    editor.putInt("MAIOR_LEVEL", Integer.valueOf(r.getMaior_nivel()));
                                    editor.putString("NOME", r.getNome());
                                    editor.putString("SENHA", r.getSenha());
                                    editor.putString("EMAIL", r.getEmail());
                                    editor.putInt("REGISTRADO", Integer.valueOf(r.getRegistrado()));
                                    editor.putInt("ID_REGISTRO", r.getID());
                                    editor.commit();

                                    Toast.makeText(logar.this, "Jogador " + obj.get("NOME").getAsString() + " logado com Sucesso!", Toast.LENGTH_LONG).show();
                                    startActivity(new Intent(getApplicationContext(), start.class));

                                } else if (result.get("LOGAR").getAsString().equals("NAOEXISTE")) {
                                    Toast.makeText(logar.this, "Nome ou senha incorretos!", Toast.LENGTH_LONG).show();
                                } else {
                                    Toast.makeText(logar.this, "Nome já utilizado!", Toast.LENGTH_LONG).show();
                                }
                            }
                        }
                    });
        }
    }


PHP do Login:

   

<?php 
    include "conexaotapball.php";
    $host = "localhost";
    $db = "id7211556_tapballusers";
    $usuario = "id7211556_zotinfotapball";
    $senhadb = "tapballthegame";
    $con = mysqli_connect($host,$usuario,$senhadb,$db);
    
    $nome =  "teste"; //$_POST['NOME'];
    $senha = "teste";// $_POST['SENHA'];
    
    $sql_login = "SELECT * FROM jogadores WHERE NOME = '$nome' AND SENHA = '$senha'";
    
    $dados_login = $PDO->query($sql_login);
    $resultado_login = array();
    
    $result = mysqli_fetch_array(mysqli_query($con,$sql_login));
    
    if(isset($result)) {
        //$dados = array("LOGAR"=>"OK");
        while($jogador = $dados_login->fetch(PDO::FETCH_OBJ)){
            $resultado_login[] = array("ID"=>$jogador->ID, "NOME"=>$jogador->NOME, "SENHA"=>$jogador->SENHA, "EMAIL"=>$jogador->EMAIL,
            "DINHEIRO"=>$jogador->DINHEIRO, "RECORDE"=>$jogador->RECORDE, "CLIQUES"=>$jogador->CLIQUES, "MAIOR_NIVEL"=>$jogador->MAIOR_NIVEL,
            "TOTAL_GANHO"=>$jogador->TOTAL_GANHO, "REGISTRADO"=>$jogador->REGISTRADO,"LOGAR"=>"OK");
        }
    } else {
        $resultado_login = array("LOGAR"=>"NAOEXISTE");    
    }
    echo json_encode($resultado_login);
    //echo json_encode($dados);
    mysqli_close($con);
?>

Sistema do Ranking:   

private void listaRanking(){

        String url = HOST + "/rankrecorde.php";

        Ion.with(getBaseContext())
                .load(url)
                .asJsonArray()
                .setCallback(new FutureCallback<JsonArray>() {
                    @Override
                    public void onCompleted(Exception e, JsonArray result) {
                        if(result == null) {
                            Toast.makeText(rankrecorde.this, "Não foi possível! Verifique sua conexão.", Toast.LENGTH_LONG).show();
                        } else {
                            for (int i = 0; i < result.size(); i++) {

                                JsonObject obj = result.get(i).getAsJsonObject();

                                rankingrecorde r = new rankingrecorde();
                                r.setNome(obj.get("NOME").getAsString());
                                r.setRecord(obj.get("RECORDE").getAsString());

                                lista.add(r);
                            }
                            rankAdapter.notifyDataSetChanged();
                        }
                    }
                });

    }

PHP que faz a função do ranking:   

 <?php
    include "conexaotapball.php";
    
    $sql_read = "SELECT * FROM jogadores ORDER BY RECORDE * 1 DESC LIMIT 10";
    //$sql_readrecord = "SELECT NAME, RECORDE FROM jogadores ORDER BY RECORDE DESC";
    $dados = $PDO->query($sql_read);
    //$dados = $PDO->query($sql_readrecord);
    
    $resultado = array();
    
    while($jogador = $dados->fetch(PDO::FETCH_OBJ)){
        $resultado[] = array("ID"=>$jogador->ID, "NOME"=>$jogador->NOME, "RECORDE"=>$jogador->RECORDE);
    }

    
    echo json_encode($resultado);
?>

Site que estou utilizando para testes:
https://zotinfogames.000webhostapp.com/tapball/logartapball.php

Aqui está a saida utilizando usuario teste direto no php de login:

   

[
{
ID: "4",
NOME: "teste",
SENHA: "teste",
EMAIL: "teste",
DINHEIRO: "205",
RECORDE: "165",
CLIQUES: "64",
MAIOR_NIVEL: "3",
TOTAL_GANHO: "205",
REGISTRADO: "1",
LOGAR: "OK"
}
]


Obrigado por qualquer ajuda que vier.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Crie uma conta ou entre para comentar

Você precisar ser um membro para fazer um comentário

Criar uma conta

Crie uma nova conta em nossa comunidade. É fácil!

Crie uma nova conta

Entrar

Já tem uma conta? Faça o login.

Entrar Agora

  • Conteúdo Similar

    • Por cesaroet
      Galera, estou com o seguinte problema:
      tenho 4 redirecionamento, até a 2 funciona normal, mas a partir da 3 redireciona para o menu.php novamente.
      alguem tem uma dica?
      <?php session_start(); if(!isset($_SESSION['usuario']) /*|| ($_SESSION['nivel']) */){ session_destroy(); header("location:menu.php"); exit; } if($_SESSION['nivel'] == '1'){ header("location:checklist_gabriel/index.php"); } if($_SESSION['nivel'] == '2'){ header("location:checklist/index.php"); } if($_SESSION['nivel'] == '3'){ header("location:conferencia/controle/"); } if($_SESSION['nivel'] == '4'){ header("location:controle/index.php"); } ?>  
    • Por jlrs19833
      Bom dia, pessoal! Estou precisando de uma luz para saber como tratar determinado problema:
       
      Cenário: Ambiente em desenvolvimento de plataforma para gestão de uma empresa.
      Linguagem principal: PHP (framework CodeIgniter)
      Dificuldade: retornar dados de select dinâmico junto ao evento de post do formulário.
       
      Descrição: Conforme mencionado acima, estou desenvolvendo um pequeno sistema para uma empresa que conterá poucas telas, sou desenvolver entusiasta, então não tenho muito conhecimento e prática com este assunto. Em determinada tela, o cliente quer que haja um formulário de cadastro onde dentre os diversos campos deste form, haverá dois do tipo select, onde um é o select de cidade e o outro do tipo estado. O select de Estado é preenchido automaticamente quando do carregamento da view, através de uma chamada do controller/model junto ao BD e o select cidade é preenchido de maneira automática, com javascript, através de uma mesma consulta, passando o ID do campo estado. Minha dificuldade está quando faço o submit deste form, pois o campo value do option deste select (cidade) não é enviado junto, pois no código fonte ele não foi carregado. Como posso fazer para recuperar esse value e enviar junto com o evento de submit?
       
      Segue como meus arquivos estão sendo feitos. Como pode observar estou, tentando apenas printar os campos para que eu possa ter certeza que eles estão sendo carregados.
      https://gist.github.com/jlrs19833/808887a5221ff31ca6ea22bf0c8b85a5
       
      Peço desculpas se estou postando no local errado e que os moderadores me orientem neste caso.
       
      Desde já agradeço o auxílio de cada um.
    • Por 4ly
      Olá. Bom basicamente eu tenho um botão âncora que leva até a aba de sobre do meu site, só que ele não tem animação, ele simplesmente "teleporta" para essa aba do nada isso não é legal. 
      Gostaria de saber algum código de JavaScript ou CSS para solucionar isso 
      Esse é o código : 
       
      <button id="explorer"><a href="#about">Explorar</a></button>
    • Por leo_santo1
      Venho por meio desse post procurar ajuda com meu código!
      Estou fazendo um código usando `DataTable` , sou iniciante na programação, depois de umas pesquisas e até mesmo algumas dicas conseguir construir uma DataTable com banco de dados.
      Continuando minhas pesquisas para aprimorar mais ainda o código, percebi que a  `DataTable` possuir varias funções interessantes, umas delas em especifico chamou bastante minha atenção e até me ajudaria no código que no caso é o uso de Linhas filhas ocultas, que quando fazemos o click em cima de um botão aparece as informações extras da linha ( no caso os dados a mais do banco ) e ao apertar ela novamente ele oculta as informações.
      Gostaria de ajuda para criar essa função na minha Tabela, já realizei pesquisas no próprio site da  `DataTable` , aqui, porem não entendo bem o jeito que eles explicam.
      segue abaixo meu código da table e da  `DataTable` que conecta com o Banco.
       
      Tabela
      <table id="employee-grid" cellpadding="0" cellspacing="0" border="0" class="display" width="100%"> <thead> <tr> <th>Nome</th> <th>CPF</th> <th>Data de Nascimento</th> <th></th> <th>Ação</th> <th></th> </tr> </thead> <thead> <tr> <td><input type="text" data-column="0" class="search-input-text" style="width: 150px;"></td> <th><input type="text" data-column="1" class="search-input-text" style="width: 150px;"></td> <th><input type="text" id="data" data-column="2" class="search-input-text" style="width: 150px;"></th> <th></th> <td> </td> <td></td> </tr> </thead> </table> Script DataTable
      $(document).ready(function() { var dataTable = $('#employee-grid').DataTable( { "processing": true, "serverSide": true, "bJQueryUI": true, "oLanguage": { "sProcessing": "Processando...", "sLengthMenu": "Mostrar _MENU_ registros", "sZeroRecords": "Não foram encontrados resultados", "sInfo": "Mostrando de _START_ até _END_ de _TOTAL_ registros", "sInfoEmpty": "Mostrando de 0 até 0 de 0 registros", "sInfoFiltered": "", "sInfoPostFix": "", "sSearch": "Buscar:", "sUrl": "", "oPaginate": { "sFirst": "Primeiro", "sPrevious": "Anterior", "sNext": "Seguinte", "sLast": "Último" } }, "ajax":{ url :"../Tabelas/Tabela_consulta_cliente.php", // json datasource type: "post", // method , by default get error: function(){ // error handling $(".employee-grid-error").html(""); $("#employee-grid").append('<tbody class="employee-grid-error"><tr><th colspan="3">No data found in the server</th></tr></tbody>'); $("#employee-grid_processing").css("display","none"); } } } ); $("#employee-grid_filter").css("display","none"); // hiding global search box $('.search-input-text').on( 'keyup click', function () { // for text boxes var i =$(this).attr('data-column'); // getting column index var v =$(this).val(); // getting search input value dataTable.columns(i).search(v).draw(); } ); $('.search-input-select').on( 'change', function () { // for select box var i =$(this).attr('data-column'); var v =$(this).val(); dataTable.columns(i).search(v).draw(); } ); } ); Conexão DataTable com o Banco de dados
      <?php $servername = "localhost"; $username = "root"; $password = ""; $dbname = "loc_equipamentos"; $conn = mysqli_connect($servername, $username, $password, $dbname) or die("Connection failed: " . mysqli_connect_error()); $requestData= $_REQUEST; $columns = array( 0=>'nome_usuario', 1=> 'cpf_usuario', 2=> 'data_nascimento', 3=> 'id_usuario', 4=> 'id_usuario', 5=> 'id_usuario' ); $sql = "SELECT nome_usuario, cpf_usuario, data_nascimento, id_usuario "; $sql.=" FROM usuario"; $query=mysqli_query($conn, $sql) or die("employee-grid-data.php: get employees"); $totalData = mysqli_num_rows($query); $totalFiltered = $totalData; . $sql = "SELECT nome_usuario, cpf_usuario, data_nascimento, id_usuario "; $sql.=" FROM usuario WHERE tipo_perfil = 'CLIENTE' AND ativo_usuario = 'TRUE'"; if( !empty($requestData['columns'][0]['search']['value']) ){ $sql.=" AND nome_usuario LIKE '".$requestData['columns'][0]['search']['value']."%' "; } if( !empty($requestData['columns'][1]['search']['value']) ){ $sql.=" AND cpf_usuario LIKE '".$requestData['columns'][1]['search']['value']."%' "; } if( !empty($requestData['columns'][2]['search']['value']) ){ //age $sql.=" AND data_nascimento LIKE '".$requestData['columns'][2]['search']['value']."%' "; } $query=mysqli_query($conn, $sql) or die("employee-grid-data.php: get employees"); $totalFiltered = mysqli_num_rows($query); $sql.=" ORDER BY ". $columns[$requestData['order'][0]['column']]." ".$requestData['order'][0]['dir']." LIMIT ".$requestData['start']." ,".$requestData['length']." "; $query=mysqli_query($conn, $sql) or die("employee-grid-data.php: get employees"); $data = array(); while( $row=mysqli_fetch_array($query) ) { $nestedData=array(); $informacao ="<div class='botaodiv'> <a href = ?informacao=".$row['id_usuario']." >+ Informações</a> </div>"; $editar ="<div class='botaodiv'> <a href = ?editar=".$row['id_usuario']." >Editar</a> </div>"; $deletar ="<div class='botaodiv'> <a href = ../Eventos/evento.php?DesativaCadastro=".$row['id_usuario']." >Excluir</a> </div>"; $nestedData[] = $row["nome_usuario"]; $nestedData[] = $row["cpf_usuario"]; $nestedData[] = $row["data_nascimento"]; $nestedData[] = $informacao; $nestedData[] = $editar; $nestedData[] = $deletar; $data[] = $nestedData; } $json_data = array( "draw" => intval( $requestData['draw'] ), "recordsTotal" => intval( $totalData ), "recordsFiltered" => intval( $totalFiltered ), "data" => $data ); echo json_encode($json_data); ?> Fora o caso de criar Detalhes para Linhas, Caso alguém tenha alguma sugestão de como melhorar meu código ( por exemplo uma Conexão ao Banco mais simples, um Js melhor etc.. ) ou alguma critica para eu evoluir, irei agradecer bastante!  
×

Informação importante

Ao usar o fórum, você concorda com nossos Termos e condições.