Ir para conteúdo

POWERED BY:

Arquivado

Este tópico foi arquivado e está fechado para novas respostas.

freitaz

Esta inserindo invés de alterar o formulário php alguém poderia me ajudar?

Recommended Posts

Essa parte é da tela de Cadastro 


                                            <?php
                                            $executivo = new Executivo();

                                            if ($_SERVER["REQUEST_METHOD"] == "GET") {
                                                //Using GET
                                                $titulo = $_GET['titulo'];
                                                $categoria = $_GET['categoria'];
                                                $file = $_GET['arquivo'];
                                                $action = $_GET['action'];
                                            }

                                            if (isset($_POST["exepublicar"])) {
                                                $titulo = $_POST['titulo'];
                                                $categoria = $_POST['categoria'];
                                                $action = $_POST['action'];
                                                $file = $_POST['filetext'];
                                                #Informações do Arquivo
                                                // Check if the form was submitted
                                                if ($_SERVER["REQUEST_METHOD"] == "POST") {
                                                    // Check if file was uploaded without errors
                                                    $filename = $_FILES["file"]["name"];
                                                    $filetype = $_FILES["file"]["type"];
                                                    $filesize = $_FILES["file"]["size"];

                                                    // Verify file extension
                                                    $ext = pathinfo($filename, PATHINFO_EXTENSION);


                                                    // Verify file size - 5MB maximum
                                                    $maxsize = 5 * 1024 * 1024;
                                                    if ($filesize > $maxsize)
                                                        die("ERRO: Tamanho máximo de arquivo igual a 5MB.");


                                                    // Check whether file exists before uploading it
                                                    if (file_exists("uploads/executivo/" . $_FILES["file"]["name"])) {
                                                        echo $_FILES["file"]["name"] . " já existe na pasta.";
                                                    } else {
                                                        move_uploaded_file($_FILES["file"]["tmp_name"], "uploads/executivo/" . $_FILES["file"]["name"]);
                                                    }
                                                }

                                                #fim do Arquivo

                                                print_r($fmsg);
                                                $executivo->setTitulo($titulo);
                                                $executivo->setCategoria($categoria);
                                                $executivo->setArquivo($filename);
                                                try {
                                                    if ($action == "alterar") {
                                                        if ($filename == "") {
                                                            $executivo->setArquivo($file);
                                                        } else {

                                                            if (file_exists("uploads/executivo/" . $file)) {
                                                                $path = 'uploads/executivo/' . $file;
                                                                unlink($path);
                                                            }
                                                        }
                                                        $executivo->update($executivo->getTitulo(), $executivo->getCategoria(), $executivo->getArquivo());
                                                        $texto = "Atualizado com sucesso";
                                                    } else {
                                                        $executivo->insert($executivo->getTitulo(), $executivo->getCategoria(), $executivo->getArquivo());
                                                        $texto = "Inserido com sucesso";
                                                    }

                                                    print_r($texto);
                                                } catch (PDOException $e) {
                                                    echo 'ERRO: ' . $e->getMessage();
                                                }
                                            }
                                            ?>

a parte da classe 

 

 public function update($titulo, $categoria, $arquivo) {
        try {
            $sql = "UPDATE $this->table SET titulo = :titulo, categoria = :categoria, arquivo= :arquivo WHERE id = :id";
            $stmt = DB::prepare($sql);
            $stmt->execute(array('id' => $id, 'titulo' => $titulo, 'categoria' => $categoria, 'arquivo' => $arquivo));
        } catch (PDOException $e) {
            echo 'ERROR: ' . $e->getMessage();
        }
    }

Quando efetuo a alteração ele insere e não atualiza, 

desde já agradeço a ajuda

Compartilhar este post


Link para o post
Compartilhar em outros sites

Não apresenta erro?!

Estranho... deveria mostrar erro nessa linha:

11 horas atrás, freitaz disse:

$stmt->execute(array('id' => $id, 'titulo' => $titulo, 'categoria' => $categoria, 'arquivo' => $arquivo));

 

Em seu método você passa por parâmetro $titulo, $categoria, $arquivo

E adiciona esses valores ao statements, o que até aí tudo bem, mas...

id = :id

'id' => $id

 

Em nenhum momento a variável $id é criada "que deveria está dentro do escopo no método", enfim, acredito que a coluna id seja INT e AUTO_INCREMENT por isso não dar erro, quando a PDO envia o valor envia NULL e o sql trata de corrigir o erro por naturalidade devido as propriedades da coluna.

Daí acredito eu que na verdade o sql pega o último registro insere +1 e registra os novos dados.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Eu exclui o id que estava errado mesmo...

 

Olha o erro que da 

 

 

 

11 horas atrás, Omar~ disse:

Daí acredito eu que na verdade o sql pega o último registro insere +1 e registra os novos dados.

 

Desculpe sou um pouco leigo em algumas coisas, o senhor poderia me explica como arrumaria esse registro do sql.

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Não deu para ver em detalhes os erros, só deu para perceber que o php dar erro ao tentar processar índices de array que não foram definidas, no casso arrays super-globais GET ou POST (não deu para ver qual é).

Isso acontece porque o arquivo que processa não recebeu esses dados e logo está tentando usar eles.

Então no que posso ajudar no momento é lhe dando dicas.

 

  • Tudo deve ser tratado antes de salvamento, o que inclui a verificação de sua existência

Exemplo:

Spoiler

<?php
if (count($_POST)) {
  // Dados de POST existem
  if (!isset($_POST['alguma_coisa'])) {
    // post alguma coisa não existe
  } else if (empty($_POST['alguma_coisa'])) {
    // post alguma coisa está vazio
  } else if ((strlen($_POST['alguma_coisa']) < 5) || (strlen($_POST['alguma_coisa']) > 10)) {
    // post alguma coisa ou possui menos de 5 caracteres ou mais de 10
  } else if (!preg_match('/^([a-zA-Z À-ú 0-9]+)$/i', $_POST['alguma_coisa'])) {
    // O valor  de post alguma coisa possui algum tipo de caractere expecial que não é espaço
  }
  // ----
  else {
    // terminei as verificações que queria fazer, entro com o restante do código
  }
} else {
  // O arquivo não recebou nenhum índice a super-global POST
}

 

E por aí vai, fazendo todo e qualquer tipo de verificação dos dados antes de querer usar-los, Lógico que isso é um exemplo genérico, pois o tratamento de um input vai muito mais além, na prática é possuir um método de uma classe para fazer a verificação, justamente para não ficar recriando toda uma sequência de código para cada entrada de um post como exemplo, assim sendo podemos convocar o método de verificação apenas passando por parâmetro o dado que queremos verificar.

 

  • Antes da manipulação de dados confirme sua existência, um truque é depurar antes de começar.

Exemplo como eu faço:

Digamos então que eu vá salvar dados de um formulário. Vou lá crio o form com os inputs e tudo mais (SEM FORMATAÇÃO CSS o design é a última coisa que se deve pensar em fazer por ser a coisa mais simples).

Então vou enviar os dados para o arquivo salva.php. Antes de começar a escrever o salva.php coloco isso nele.

var_dump($_POST); isso se eu estiver a enviar dados do tipo post se for get usa-se $_GET.

O php vai me informar corretamente todos os dados que eu enviei, basta que eu der um CTRL + C no resultado na tela que eu terei corretamente todos os inputs, assim previno erros de digitação que normalmente geram (Notice: Undefined index)

 

  • Tenha bom senso na identação e lógica programacional.

Fica muito mais simples para você ou outra pessoa dar manutenção no sistema no futuro. (A falta do conceito das boas práticas é o que mais me estressa quando sou contratado para consertar aplicações "é cada coisa bizarra que chega em minhas mãos")

Veja algumas incoerências de seu arquivo:

Em 16/10/2018 at 11:41, freitaz disse:

if ($_SERVER["REQUEST_METHOD"] == "GET") {

Isso não está errado. A condição diz se o servidor enviar um get faça, mas....

 

Em 16/10/2018 at 11:41, freitaz disse:

if (isset($_POST["exepublicar"])) {

Dentro dessa condição está

Em 16/10/2018 at 11:41, freitaz disse:

if ($_SERVER["REQUEST_METHOD"] == "POST") {

Se já existe o post porque verificar se o método de envio é post?

Mas o tratamento inicial não era get?

 

Por fim:

3 horas atrás, freitaz disse:

Eu exclui o id que estava errado mesmo...

E como vai fazer o updade se não não informar qual registro é para atualizar?

Você deveria capturar no caso o ID através de um select no formulário e repassar esse valor para o arquivo que vai salvar os dados, lógico que o método update deve ter a condicional na entrada de parâmetros.

 

Obs.: A PDO não faz updade se realmente não houver modificações em dados. Na simples explicação é como se a biblioteca fizesse a leitura comparasse os dados, se estão iguais, nada acontece.

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por violin101
      Caros amigos, saudações.
       
      Por favor, me permita tirar uma dúvida com os amigos.

      Tenho um Formulário onde o Usuário digita todos os Dados necessários.

      Minha dúvida:
      --> como faço após o usuário digitar os dados e salvar, o Sistema chamar uma Modal ou mensagem perguntando se deseja imprimir agora ?

      Grato,
       
      Cesar
    • Por Carcleo
      Tenho uma abela de usuarios e uma tabela de administradores e clientes.
      Gostaria de uma ajuda para implementar um cadastro
       
      users -> name, login, passord (pronta) admins -> user_id, registratiom, etc.. client -> user_id, registratiom, etc...
      Queria ajuda para extender de user as classes Admin e Client
      Olhem como estáAdmin
      <?php namespace App\Models; use Illuminate\Database\Eloquent\Factories\HasFactory; use Illuminate\Database\Eloquent\Model; class Admin extends User {     use HasFactory;            protected $fillable = [         'name',         'email',         'password',         'registration'     ];      private string $registration;     public function create(         string $name,          string $email,          string $password,         string $registration     )     {         //parent::create(['name'=>$name, 'email'=>$email, 'password'=>$password]);         parent::$name = $name;         parent::$email = $email;         parent::$password = $password;         $this->registration = $registration;     } } User
      <?php namespace App\Models; // use Illuminate\Contracts\Auth\MustVerifyEmail; use Illuminate\Database\Eloquent\Factories\HasFactory; use Illuminate\Foundation\Auth\User as Authenticatable; use Illuminate\Notifications\Notifiable; use Illuminate\Database\Eloquent\Relations\BelongsToMany; class User extends Authenticatable {     /** @use HasFactory<\Database\Factories\UserFactory> */     use HasFactory, Notifiable;     static string $name;     static string $email;     static string $password;     /**      * The attributes that are mass assignable.      *      * @var list<string>      */     protected $fillable = [         'name',         'email',         'password',     ];          /**      * The attributes that should be hidden for serialization.      *      * @var list<string>      */     protected $hidden = [         'remember_token',     ];     /**      * Get the attributes that should be cast.      *      * @return array<string, string>      */     protected function casts(): array     {         return [             'email_verified_at' => 'datetime',             'password' => 'hashed',         ];     }          public function roles() : BelongsToMany {         return $this->belongsToMany(Role::class);     }       public function hasHole(Array $roleName): bool     {                 foreach ($this->roles as $role) {             if ($role->name === $roleName) {                 return true;             }         }         return false;     }         public function hasHoles(Array $rolesName): bool     {                 foreach ($this->roles as $role) {             foreach ($rolesName as $rolee) {             if ($role->name === $rolee) {                 return true;             }          }         }         return false;     }         public function hasAbility(string $ability): bool     {         foreach ($this->roles as $role) {             if ($role->abilities->contains('name', $ability)) {                 return true;             }         }         return false;     }     } Como gravar um Admin na tabela admins sendo que ele é um User por extensão?
      Tentei assim mas é claro que está errado...
      public function store(Request $request, Admin $adminModel) {         $dados = $request->validate([             "name" => "required",             "email" => "required|email",             "password" => "required",             "registration" => "required"         ]);         $dados["password"] =  Hash::make($dados["password"]);                  $admin = Admin::where("registration",  $dados["registration"])->first();                  if ($admin)              return                    redirect()->route("admin.new")                             ->withErrors([                                 'fail' => 'Administrador já cadastrados<br>, favor verificar!'                   ]);                            $newAdmin = $adminModel->create(                                    $dados['name'],                                    $dados['email'],                                    $dados['password'],                                    $dados['registration']                                 );         dd($newAdmin);         $adminModel->save();         //$adminModel::create($admin);                  return redirect()->route("admin.new")->with("success",'Cadastrado com sucesso');     }  
    • Por violin101
      Caros amigos, saudações.
       
      Gostaria de tirar uma dúvida com os amigos, referente a PDV.
       
      Estou escrevendo um Sistema com Ponto de Vendas, a minha dúvida é o seguinte, referente ao procedimento mais correto.

      Conforme o caixa vai efetuando a venda, o Sistema de PDV já realiza:
      a baixa direto dos produtos no estoque
      ou
      somente após concretizar a venda o sistema baixa os produtos do estoque ?
       
      Grato,
       
      Cesar
       
    • Por violin101
      Caros amigos do grupo, saudações e um feliz 2025.
       
      Estou com uma pequena dúvida referente a Teclas de Atalho.

      Quando o Caps Lock está ativado o Comando da Tecla de Atalho não funciona.
      ou seja:
      se estiver para letra minúscula ====> funciona
      se estiver para letra maiúscula ====> não funciona
       
      Como consigo evitar essa falha, tanto para Letra Maiúscula quanto Minúscula ?

      o Código está assim:
      document.addEventListener( 'keydown', evt => { if (!evt.ctrlKey || evt.key !== 'r' ) return;// Não é Ctrl+r, portanto interrompemos o script evt.preventDefault(); });  
      Grato,
       
      Cesar
    • Por violin101
      Caros amigos, saudações.
       
      Por favor, poderiam me ajudar.

      Estou com a seguinte dúvida:
      --> como faço para para implementar o input código do produto, para quando o usuário digitar o ID o sistema espera de 1s a 2s, sem ter que pressionar a tecla ENTER.

      exemplo:
      código   ----   descrição
           1       -----   produto_A
       
      Grato,
       
      Cesar
×

Informação importante

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