Ir para conteúdo

POWERED BY:

Sapinn

Como fazer upload de arquivo com PDO

Recommended Posts

Estou precisando salvar fotos dos usuários de um sistema e não estou conseguindo fazer com OO já assisti video aulas e li algumas matérias mas sempre dá erro. Alguém sabe algum jeito de se fazer?? Eu até tentei mas fica sempre com erro, vou postar aqui talvez tenha algo que eu esteja fazendo errado.

 

class para salvar a foto:

   private function salvarFoto($foto){

        $fotos = $_FILES['foto_admin'];

        $fotoDir = "imagens/fotos_admins/";

        $fotoPath = $fotoDir . basename($foto['foto_admin']['name']);

        $fotoTmp = $foto['foto_admin']['tmp_name'];



        if(move_uploaded_file($fotoTmp, $fotoPath)):

            return $fotoPath;

        else:

            return false;

        endif;

    }

E estou chamando ela assim:

 $upload = $this->salvarFoto($_FILES);

                if(gettype($upload) == 'string'):

                    $dados['foto_admin'] = $upload;

                endif;

 

E o erro é o seguinte: move_uploaded_file(imagens/fotos_admins/sapinn.jpg): failed to open stream: No such file or directory in

 

Não sei o que está errado a pasta imagens/fotos_admins está dentro da minha pasta Controller

Compartilhar este post


Link para o post
Compartilhar em outros sites

Mas a classe também está nessa pasta Controller?

Acredito que não...

Tente usar a constante __DIR__ para obter o diretório atual e a partir dele indicar o local do outro diretório.

Exemplo:

$diretorio = __DIR__ . '/../imagens/fotos_admins/';

Nesse caso do diretório onde executamos escape um diretório atrás e entre em imagens.....

Lógico que o(s) escape(s) depende da arquitetura dos diretórios do seu projeto.

 

Esse é um truque muito eficiente que evita qualquer erro de localização de diretórios ou arquivos.

 

Veja essa classe:

https://github.com/Spell-Master/source-map/blob/master/system/class/model/ImageUpload.php

<?php

switch ($_FILES['foto_admin']['type']) {
  case 'image/jpg':
  case 'image/jpeg':
  case 'image/pjpeg':
  case 'image/png':
  case 'image/x-png':
    break;
  default:
    echo ("Vai dar erro ao tentar salvar pois o tipo de imagem não é aceito pela classe");
}

$diretorio = __DIR__ . '/../imagens/';
$imagem = new ImageUpload($diretorio);
$imagem->sendImage($_FILES['foto_admin'], 'Nome para imagem', 1024);

if ($imagem->getResult()) {
  $nomeDaImagem = $imagem->getImgName();
  echo ("No diretório {$diretorio} uma imagem foi armazenada e seu nome é {$nomeDaImagem}");
} else {
  echo ("A imagem não pode ser armazenada");
}


Vale lembrar também que dependendo do assunto dar para recriar a imagem no servidor sem que o usuário faça upload, bastando apenas ler seus metadados e inserir o mesmo em um campo de formulário e então enviar esses dados, e com essa informação compilar a imagem no servidor.

Mas nesse caso a questão é mais javascript do que php, e um recurso para esse afim é o FileReader

Compartilhar este post


Link para o post
Compartilhar em outros sites

Obrigado Omar me salvou de novo, no meu caso só tava faltando o __DIR__ mesmo. Mas agora estou com outro problema não estou conseguindo chamar a imagem

Compartilhar este post


Link para o post
Compartilhar em outros sites

Ressaltando que a constante __DIR__ não serve para renderização, e eu acho que possa ser esse caso de achar a imagem.

Exemplo:

<img src="<?= __DIR__ . '/diretorio/imagem.jpg' ?>" alt="Ops! a constante não serve para esse caso" />

Tente localizar a imagem a partir da raiz onde se encontra o index.

E claro verifique se realmente a imagem foi salva.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Eu tentei e não consegui. Você acha que é uma má pratica eu salvar as imagens na minha pasta public e depois chama-las ??

Compartilhar este post


Link para o post
Compartilhar em outros sites

Má prática não é. O problema é organização mesmo.

 

Digamos a seguinte estrutura de arquivo na raiz.

index.php

imagens/arquivos/

forms/enviar.php

foo/mostrar.php

 

Aí nesse caso enviar.php é o arquivo que vai salvar um upload dentro de imagens/arquivos/ logo para um script serve-side eu uso __DIR__ . '/../../imagens/arquivos/' então facilmente localizo o diretório para salvar o arquivo digamos exemplo.jpg.

Mas então quero ver a imagem em mostrar.php nesse caso uso o esquema html.

<img src="../../imagens/arquivos/exemplo.jpg" alt="a imagem não foi carregada" />

 

Porém digamos que eu esteja usando um modo de reescrita do apache onde tudo volta ao index aí a coisa muda

<img src="imagens/arquivos/exemplo.jpg" alt="a imagem não foi carregada" />

 

O negócio é você ir testando ai até encontrar a forma de endereçar a imagem corretamente.

 

#EDIT:

Citar

Há um problema em salvar arquivos de usuários em algum diretório que contenha algum arquivo sensível da aplicação, digamos na raiz onde está o index. Se não fazer um refinamento detalhado no arquivo que vai armazenar, esse usuário pode usar o upload para corromper, editar ou substituir arquivos no mesmo endereço através do próprio arquivo que ele envia.

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Entendi... Eu estou fazendo esse sistema em MVC usando .htacess para as URL com isso eu não consigo acessar os arquivos dentro da pasta app no caso na imagem, todavia, eu consigo colocar ele na pasta public dentro de uma pasta chamada img_user. Para chamar a imagem eu uso uma contante com uma url pré definida, assim:

 

CONST.'/img_user/'.$user->foto

 

E está funcionando, tentei outras formas mas não consegui fazer. 

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 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
    • Por violin101
      Caros amigos, saudações.
       
      Humildemente peço desculpa por postar uma dúvida que tenho.

      Preciso salvar no MySql, os seguinte Registro:

      1 - Principal
      ====> minha dúvida começa aqui
      ==========> como faço para o Sistema Contar Automaticamente o que estiver despois do 1.____?
      1.01 - Matriz
      1.01.0001 - Estoque
      1.01.0002 - Oficina
      etc

      2 - Secundário
      2.01 - Loja_1
      2.01.0001 - Caixa
      2.01.0002 - Recepção
      etc
       
      Resumindo seria como se fosse um Cadastro de PLANO de CONTAS CONTÁBEIL.

      Grato,


      Cesar









       
×

Informação importante

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