Ir para conteúdo
Victor Penna

Duvidas: Framework Codeigniter Funções

Recommended Posts

Boa tarde pessoal, venho aqui denovo pedir uma ajuda de vocês... 

Estou participando de um projeto com amigos do curso, logo precisamos construir um app android, que se comunique com um webservice pratico e um banco de dados estável. 4

Logo nos dividimos, ficando eu e outro colega responsavel pelo webservice, como conheço muito pouco de PHP(muito mesmo), nos aventuramos em tentar fazer uma API RESTFULL, com framework Codeigniter. Bom a principio está sendo um otimo aprendizado, pois enfrentamos varios desafios, principalmente por conta do aprendizado da linguagem, porém minha duvida é referente as funções de requisição dentro do framework.

Na nossa pasta controllers, fizemos algumas varias funções, ela consegue fazer todos os chamados corretamente, contudo algumas funções não entendemos:

 

Função GET:

    public function perfil_get(){
        $info = $this->get();
        $usuario_id = json_decode($info);
        $usuario = $this->api_model->get_usuario($usuario_id);
        $this->response($usuario);

Já na model, ela chama essa:

public function get_usuario($usuario_id){
  // $this->db->where('id',$usuario_id);
  //função que resgata as informações determinadas, a varaivel $usuario_id na coluna id da tabela consumidores.
  $query = $this->db->get('SELECT `nome`, `email`, `endereco`, `telefone`, `bairro`, FROM `consumidores` WHERE id', $usuario_id);
  $row = $query->result_array();
  // retorno com as informações captadas pelo banco.
  return $row;

Mas ele não consegue capturar as informações que passamos... Poderia me explica como consertar, fazer uma chamada melhor em GET?

 

Função POST:

Nessa função das pasta controllers, desejamos capturar as informações de login e senha do usuário, para checar no banco e fazemos a conexão no app, mas ele não faz a checagem.

public function validacao_post(){
        $info = $this->post();
        $login_valido = json_decode($info);
        list($login,$senha) = $login_valido;
        $teste= $this->api_model->validar_usuario($login,$senha);
        if($teste==1){
            $mensagem = 'Logado com sucesso';
            $this->response($mensagem);
        }else{
            $mensagem = null;
            $this->response($mensagem);
        }
    }

Model: 

 

  *Metodo que ira validar os dados(login e senha) do usuario.
  *recebe como parâmetro as variaveis $login e $senha e retorna 1 se login existir, 0 oposto.
  */
  public function validar_usuario($login,$senha){
    //funções que comprovam se os dados dentro de $login e $senha correspondem a login e senha do usuario existem.
    $query = $this->db->get('SELECT `login`, FROM `consumidores` WHERE  => login',$login);
    $query_two = $this->db->get('SELECT `senha`, FROM `consumidores` WHERE  => senha',$senha);
    // condição de verificação, se for real(existir) retorna 1, sendo falsa retorna 0.
    if(isset($query) && isset($query_two)){
      $mensagem = 1;
    }else{
      $mensagem = 0;
    }
    return
}

Fico no aguardo pessoal da ajuda e conselhos de todos.

Grande abraço.

Editado por Gabriel Heming
Adicionar formatação em código

Compartilhar este post


Link para o post
Compartilhar em outros sites

Se estão começando utilizar o PHP, talvez fosse melhor usar ele puro ao invés de usar um framework. E se está usando o framework é necessário que leia sobre a documentação dele, no caso do Codeigniter a documentação está aqui: https://www.codeigniter.com/user_guide/index.html

 

Se ler a documentação, vai observar que não deve usar $this->get() e $this->input->get()... Acho que o código precisa ser revisto, já verificou se os dados no controller está chegando de forma correta? Utilize o debug, var_dump(), etc....

  • -1 2

Compartilhar este post


Link para o post
Compartilhar em outros sites
2 horas atrás, Elemke disse:

Se estão começando utilizar o PHP, talvez fosse melhor usar ele puro ao invés de usar um framework. E se está usando o framework é necessário que leia sobre a documentação dele, no caso do Codeigniter a documentação está aqui: https://www.codeigniter.com/user_guide/index.html

 

Se ler a documentação, vai observar que não deve usar $this->get() e $this->input->get()... Acho que o código precisa ser revisto, já verificou se os dados no controller está chegando de forma correta? Utilize o debug, var_dump(), etc....

Boa noite Elemke, na verdade o framework em si ele não é feito para serviço RESTFULL, porém foi feito uma adaptação por outro desenvolvedores, facilitando o processo(no caso, eles criaram uma biblioteca REST, só para o framework.). Sim fazemos uso da documentação do codeigniter diversas vezes, assim como usamos como guia um site chamado  "universidadecodeigniter", para conseguir desenvolver os codigos, que em sua maioria funcionaram. Nossa duvida mesmo é quanto aos codigos de recebimento GET e POST, justamente nesse framework. Como já estamos em fase de termino da implementação, estamos um pouco perdidos nesses erros. 

Mas pode ficar tranquilo companheiro, que o projeto em si ele está bem fundamentado, mesmo com pouco aprendizado em PHP, conseguimos fazer bastante coisa, porém como não temos muitos colegas ou amigos que entendam da linguagem, ficamos um pouco perdidos quanto a isso.

 

Posso colocar a API e o Model aqui, caso queriam dar uma olhada...

Compartilhar este post


Link para o post
Compartilhar em outros sites

Conheço bem pouco este FW, mas parece que a sintaxe esta errada

$this->db->get('SELECT `login`, FROM `consumidores` WHERE  => login',$login);

O correto seria algo neste sentido, se não me engando este FW usa active recorde

 

 $this->db->get('consumidores', array( 'login' => $login] ) );

Ou seja passar os parâmetros por array

 

Saída vai ser algo assim
 

SELECT * FROM consumidores WHERE login = 'seu_login'

Para filtrar os campos

 

$this->db->select('login');
$this->db->get('consumidores', ['login' => $login]);

 

Obs.: Não conheço nada deste FW, mas padrão de Active Record é desta forma.

 

Só para clarificar. :tounge_wink:

Compartilhar este post


Link para o post
Compartilhar em outros sites

No seu model tente utilizar:

 

public function get_usuario ($tabela, $condicao) {
  $this->db->where($condição);
  //onde $condição é um array, exemplo: $condição = array ('Id' => $idusuario)
  return $this->db->get($tabela);
  //onde tabela é a sua tabela do banco de dados.
}

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Utilize o profiler do codeigniter para verificar se os parâmetros estão sendo enviados corretamente no get/post e as querys que estão sendo executadas. Basta habilitar no seu controller

$this->output->enable_profiler(TRUE);

Isso vai te ajudar muito na validação.

Compartilhar este post


Link para o post
Compartilhar em outros sites
5 horas atrás, Elemke disse:

Utilize o profiler do codeigniter para verificar se os parâmetros estão sendo enviados corretamente no get/post e as querys que estão sendo executadas. Basta habilitar no seu controller


$this->output->enable_profiler(TRUE);

Isso vai te ajudar muito na validação.

Elemke, estamos usando o POSTMAN para fazer o serviço de requisições, porém ele não anda respondendo ao POST corretamente. Será que usando o profiler, isso é corrigido?

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Pessoal, agora ta acontecendo algo estranho depois de ter modificado essas funções...
 

Como se codeigniter não estivesse recebendo as função ou convertendo corretamente, sabem informar o porque?

Message: json_decode() expects parameter 1 to be string, array given

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Ao que parece está chegando para o json_decode()  um array/objeto, mas ao que indica o erro ele está procurando uma string.

$info = $this->post();
        $login_valido = json_decode($info);

tente colocar assim:

 

$info = $this->post('nomevariavel');
$login_valido = json_decode($info);

 

Compartilhar este post


Link para o post
Compartilhar em outros sites
2 minutos atrás, marcelobbt disse:

Ao que parece está chegando para o json_decode()  um array/objeto, mas ao que indica o erro ele está procurando uma string.


$info = $this->post();
        $login_valido = json_decode($info);

tente colocar assim:

 


$info = $this->post('nomevariavel');
$login_valido = json_decode($info);

 

marcelobbt, tenho um problema estamos fazendo a api rest, para um app android....

Como irei colocar um nome nessa variável que estaremos recebendo?

Compartilhar este post


Link para o post
Compartilhar em outros sites

Eu vi $this->post() e parecia ser um form, então a ideia era colocar o nome do campo que você deseja. Sendo mais de um campo cria várias variáveis.

 

Mas esse caso do api rest não tenho ideia de como funciona e nem de como é o formato que chega os dados.

 

de um var_dump ($info) para identificar o formato dos dados e depois tenta separar em strings.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Pessoal muito obrigado a todos, nesse período que vocês me ajudaram conseguir resolver os problemas daquele momento. 

Moderador, por favor pode dar como encerrado e respondido.

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 BTK
      Boa noite, estou tentando criar um curl que faz cadastro no site(o proprietário está ciente disso) porem ele está me retornando (HTTP/1.1 100 Continue HTTP/1.1 302 Moved Temporarily)

       $ch = curl_init();   
          
                                                                                                                     
          curl_setopt($ch, CURLOPT_URL, "https://www.cafefacil.com.br/customer/account/create/");                                     
          curl_setopt($ch, CURLOPT_HEADER, true);                                                                                                   
          curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (Windows NT 6.1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/72.0.3626.121 Safari/537.36');                                                                                                                                               
          curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 0);                                                                                         
          curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 0);                                                                                       
          curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true);                                                                                       
          curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);  
          curl_setopt($ch, CURLOPT_COOKIESESSION, true);                                                                             
          curl_setopt($ch, CURLOPT_COOKIEJAR, getcwd().'/cafefacil.txt');
          curl_setopt($ch, CURLOPT_COOKIEFILE, getcwd().'/cafefacil.txt'); 
          
          
          
          
          $b1 = curl_exec($ch);
          
          $form_key = value($b1, 'type="hidden" name="form_key" value="', '"');
          
          curl_setopt($ch, CURLOPT_URL, 'https://www.cafefacil.com.br/customer/account/createpost/');                                     
          curl_setopt($ch, CURLOPT_HEADER, true);                                                                                                   
          curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (Windows NT 6.1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/72.0.3626.121 Safari/537.36');                                                                                                                                                  
          curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 0);                                                                                         
          curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 0);                                                                                    
          curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true);                                                                                       
          curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); 
          curl_setopt($ch, CURLOPT_COOKIESESSION, true);   
          curl_setopt($ch, CURLOPT_REFERER, 'https://www.cafefacil.com.br/customer/account/create/');                                                                           
          curl_setopt($ch, CURLOPT_COOKIEJAR, getcwd().'/cafefacil.txt');
          curl_setopt($ch, CURLOPT_COOKIEFILE, getcwd().'/cafefacil.txt'); 
          curl_setopt($ch, CURLOPT_POST, 1);                                                                                                    
          $boundary = '---------------------------WebKitFormBoundaryRQ3KHJbpfmPf11v6';
          
          $data = '-----------------------------'.$boundary.'
          Content-Disposition: form-data; name="success_url"
          
          
          -----------------------------'.$boundary.'
          Content-Disposition: form-data; name="error_url"
          
          
          -----------------------------'.$boundary.'
          Content-Disposition: form-data; name="form_key"
          
          '.$form_key.'
          -----------------------------'.$boundary.'
          Content-Disposition: form-data; name="tipopessoa"
          
          15
          -----------------------------'.$boundary.'
          Content-Disposition: form-data; name="firstname"
          
          NomeTest SobreNomeTest
          -----------------------------'.$boundary.'
          Content-Disposition: form-data; name="nomefantasia"
          
          
          -----------------------------'.$boundary.'
          Content-Disposition: form-data; name="inscricaoestadual"
          
          
          -----------------------------'.$boundary.'
          Content-Disposition: form-data; name="email"
          
          nometestsobrenometest@gmail.com
          -----------------------------'.$boundary.'
          Content-Disposition: form-data; name="day"
          
          01
          -----------------------------'.$boundary.'
          Content-Disposition: form-data; name="month"
          
          01
          -----------------------------'.$boundary.'
          Content-Disposition: form-data; name="year"
          
          1990
          -----------------------------'.$boundary.'
          Content-Disposition: form-data; name="dob"
          
          01/01/1990
          -----------------------------'.$boundary.'
          Content-Disposition: form-data; name="taxvat"
          
          199.758.750-50
          -----------------------------'.$boundary.'
          Content-Disposition: form-data; name="celular"
          
          (11)4712-8491
          -----------------------------'.$boundary.'
          Content-Disposition: form-data; name="password"
          
          senhatest
          -----------------------------'.$boundary.'
          Content-Disposition: form-data; name="confirmation"
          
          senhatest
          -----------------------------'.$boundary.'
          Content-Disposition: form-data; name="persistent_remember_me"
          
          on
          -----------------------------'.$boundary.'--';
          
          $header[] = "Content-Type: multipart/form-data; boundary=".$boundary;
          curl_setopt($ch, CURLOPT_HTTPHEADER, $header);
          curl_setopt($ch, CURLOPT_POSTFIELDS, $data); 
          
            
          echo $exec = curl_exec($ch);
          curl_close($ch);
    • Por allencar.limma
      Tento incluir as informações de um formulário no banco de dados e não consigo. conforme código abaixo.
      <? /*Incluir as informações no formulario */ include "config.php"; $nome = trim($_POST['nome']); $masp = trim($_POST['masp']); $cpf = trim($_POST['cpf']); $telefone = trim($_POST['telefone']); $email = trim($_POST['email']); $endereco = trim($_POST['endereco']); $data_nascimento = trim($_POST['data_nascimento']); $unidade_lotacao = trim($_POST['unidade_lotacao']); /* Vamos checar algum erro nos campos */ if ((!$nome) || (!$masp) || (!$cpf) || (!$telefone) || (!$email) || (!$endereco) || (!$data_nascimento) || (!$unidade_lotacao)){ echo "ERRO: <br /><br />"; if (!$nome){ echo "Nome Completo é requerido.<br />"; } if (!$masp){ echo "Masp é requerido.<br />"; } if (!$cpf){ echo "CPF é requerido.<br /)>"; } if (!$telefone){ echo "Telefone é requerido.<br />"; } if (!$email){ echo "Email é requerido.<br />"; } if (!$endereco){ echo "Endereço é requerido.<br />"; } if (!$data_nascimento){ echo "Data de Nascimento é requerido.<br />"; } if (!$unidade_lotacao){ echo "Unidade de Lotação é requerido.<br>"; } echo "Preencha os campos abaixo: <br />"; include "formulario_cadastro.php"; }else { /* Vamos checar se o nome de Usuário escolhido e/ou Email já existem no banco de dados */ $sql_email_check = mysql_query( "SELECT COUNT(usuario_id) FROM usuarios WHERE email='{$email}'" ); $sql_masp_check = mysql_query( "SELECT COUNT(usuario_id) FROM usuarios WHERE masp='{$masp}'" ); $sql_cpf_check = mysql_query( "SELECT COUNT(usuario_id) FROM usuarios WHERE cpf='{$cpf}'" ); $eReg = mysql_fetch_array($sql_email_check); $uReg = mysql_fetch_array($sql_masp_check); $uReg = mysql_fetch_array($sql_cpf_check); $email_check = $eReg[0]; $masp_check = $uReg[0]; $cpf_check = $uReg[0]; if (($email_check > 0) || ($masp_check > 0) || ($cpf_check > 0)){ echo "<strong>ERRO</strong>: <br /><br />"; if ($email_check > 0){ echo "Este email já está sendo utilizado.<br /><br />"; unset($email); } if ($masp_check > 0){ echo "Este Masp já está sendo utilizado.<br /><br />"; unset($masp); } if ($cpf_check > 0){ echo "Este CPF já está sendo utilizado.<br /><br />"; unset($cpf); } include "formulario_cadastro.php"; }else{ /* Se passarmos por esta verificação ilesos é hora de finalmente cadastrar os dados. Vamos utilizar uma função para gerar a senha de forma randômica*/ function makeRandomPassword(){ $salt = "abchefghjkmnpqrstuvwxyz0123456789"; srand((double)microtime()*1000000); $i = 0; while ($i <= 7){ $num = rand() % 33; $tmp = substr($salt, $num, 1); $pass = $pass . $tmp; $i++; } return $pass; } $senha_randomica = makeRandomPassword(); $senha = md5($senha_randomica); // Inserindo os dados no banco de dados //$cpf = htmlspecialchars($cpf); ***RETIRADO PELO FATO DE NÃO ESTA SENDO USADO $sql = mysql_query( "INSERT INTO usuarios (none, masp, cpf, telefone, email, endereco, data_nascimento, unidade_lotacao) VALUES ('$nome', '$masp', '$cpf', '$telefone', '$email', '$endereco', '$data_nascimento', '$unidade_lotacao', now())") or die( mysql_error() ); if (!$sql){ echo "Ocorreu um erro ao criar sua conta, entre em contato."; }else{ $usuario_id = mysql_insert_id(); // Enviar um email ao usuário para confirmação e ativar o cadastro! $headers = "MIME-Version: 1.0\n"; $headers .= "Content-type: text/html; charset=iso-8859-1\n"; $headers .= "From: RCI - <rci@rcionline.com.br>"; $subject = "Confirmação de cadastro - www.rcionline.com.br"; $mensagem = "Prezado {$nome} {$masp},<br /> Obrigado pelo seu cadastro em nosso site, <a href='http://www.rcionline.com.br'> http://www.rcionline.com.br</a>!<br /> <br /> Para confirmar seu cadastro e ativar sua conta em nosso site, podendo acessar à áreas exclusivas, por favor clique no link abaixo ou copie e cole na barra de endereço do seu navegador.<br /> <br /> <a href='http://www.rcionline.com.br/ativar.php?id={$usuario_id}&code={$senha}'> http://www.rcionline.com.br/ativar.php?id={$usuario_id}&code={$senha} </a> <br /> <br /> Após a ativação de sua conta, você poderá ter acesso ao conteúdo exclusivo efetuado o login com os seguintes dados abaixo:<br > <br /> <strong>Usuario</strong>: {$usuario_id}<br /> <strong>Senha</strong>: {$senha_randomica}<br /> <br /> Obrigado!<br /> <br /> Webmaster<br /> <br /> <br /> Esta é uma mensagem automática, por favor não responda!"; mail($email, $subject, $mensagem, $headers); echo "Foi enviado para seu email - ( ".$email." ) um pedido de confirmação de cadastro, por favor verifique e sigas as instruções!"; } } } ?>  
    • Por vinicius.david
      Gostaria que fosse possível encontrar produtos pela marca no Opencart 2.3.0.2. Quando a pessoa digitar no buscar a marca do produto, ele deveria mostrar todos os produtos que pertencem aquela marca. Em catalog/model/catalog/product.php já existe por padrão a função de procurar por fabricante: 

      if (!empty($data['filter_manufacturer_id'])) {                 $sql .= " AND p.manufacturer_id = '" . (int) $data['filter_manufacturer_id'] . "'";             }
      Mas ela não faz a função de procurar por marca. Alguém já encontrou alguma solução na internet para este caso?
    • Por manolegal
      Bom dia.
      Recebo em meu formulário um dado em forma de url.
      Extraio desta url o CNPJ da empresa. A seguir faço uma pesquisa para verificar se este CNPJ está em minha base de dados, sendo que se estiver trago dados da empresa para preenchimento do campo empresa do formulário.
      Estando a empresa no BD, consigo trazer os dados corretamente, porém estes dados não passados para o formulário para serem o valor inicial do campo empresa.
      $cnpj_numero = 12345678910; $Sql_cnpj = "SELECT id_empresa as id_empresa_bd_ext, upper(empresas.empresa) as fornecedor_bd_ext FROM empresas WHERE empresas.cnpj = '$cnpj_numero'"; $Resultado_cnpj = executa($Sql_cnpj); while ($linha_cnpj = pg_fetch_array($Resultado_cnpj)){ $empresa_bd_ext = $linha_cnpj["fornecedor_bd_ext"]; $forn_hid_bd_ext = $linha_cnpj["id_empresa_bd_ext"]; } echo "Fornecedor BD: $empresa_bd_ext - $forn_hid_bd_ext<br><hr>"; // Está mostrando dados corretamente // Definir valor a ser recebido pelo campo Empresa do Formulário if ($cnpj_numero != ""){ $empresa = $empresa_bd_ext; $forn_hid = $forn_hid_bd_ext; }else{ // Caso url não tenha trazido CNPJ, atribuo outro valor $empresa = $empresa_bd; $forn_hid = $forn_hid_bd; } O campo empresa do formulário não está recebendo o valor de $empresa. Considerando que exista um CNPJ, onde pode estar o problema?
    • Por edvaldo123
      Olá para todos, preciso de um código em PHP ou HMTL que mostre cotações de moedas, pra colocar em um site de notícias. Vou deixar um link abaixo onde tem exatamente o que preciso, porém queria remover algumas linhas desse código para não identificar seu site de origem.

      http://www.precododolar.com/widgets/cotacao.php
×

Informação importante

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