Ir para conteúdo

Arquivado

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

Marcio_123

Upload de arquivos excluir acentuação

Recommended Posts

Ola Pessoal blz.

 

To fazendo um upload de arquivos no banco, mas meu script esta enviando toda acentuação especial - "ação, é ô á ê ÃÇÉ " e na hora de abrir o arquivos da erro, não abre por causa dessa acentuação. o que poderia inserir na linha abaixo para remover os acentos.

$arquivo = $_FILES['arquivo']['name'];				//PEGA O ARQUIVO DE FOTO
$tmpFile = $_FILES['arquivo']['tmp_name'];			//ARQUIVO TEMPORARIO DA FOTO
$cod = date('dmY_his') . '_' . $_FILES["arquivo"]["name"];     // GERA UM NOME PARA IMAGEM PEGANDO A DATA E HORA
$upload = "../Arquivos/".$cod;				        //PASTA ONDE A FOTO ESTA SENDO ENVIADA.
	if(move_uploaded_file($tmpFile, $upload)){
	
	//**** AQUI GRAVA NO BANCO DE DADOS
	$sql = "INSERT INTO $tabela VALUES ('','$id','$nome','$cadastro','$cod','S')";
	$sql2 = mysql_query($sql);

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

tenta isso ve se resolve

 

<?php
	function slug( $string ) {
		if (is_string($string)) {
		$string = strtolower(trim(utf8_decode($string)));
		$before = 'ÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖØÙÚÛÜÝÞßàáâãäåæçèéêëìíîïðñòóôõöøùúûýýþÿRr';
		$after  = 'aaaaaaaceeeeiiiidnoooooouuuuybsaaaaaaaceeeeiiiidnoooooouuuyybyRr';           
		$string = strtr($string, utf8_decode($before), $after);
		$replace = array(
			'/[^a-z0-9.-]/'	=> '-',
			'/-+/'			=> '-',
			'/\-{2,}/'		=> ''
			);
		$string = preg_replace(array_keys($replace), array_values($replace), $string);
			}
		return $string;
		}

$arquivo = $_FILES['arquivo']['name'];				//PEGA O ARQUIVO DE FOTO
$tmpFile = $_FILES['arquivo']['tmp_name'];			//ARQUIVO TEMPORARIO DA FOTO
$cod = date('dmY_his') . '_' . slug($_FILES["arquivo"]["name"]);     // GERA UM NOME PARA IMAGEM PEGANDO A DATA E HORA
$upload = "../Arquivos/".$cod;				        //PASTA ONDE A FOTO ESTA SENDO ENVIADA.
	if(move_uploaded_file($tmpFile, $upload)){
	
	//**** AQUI GRAVA NO BANCO DE DADOS
	$sql = "INSERT INTO $tabela VALUES ('','$id','$nome','$cadastro','$cod','S')";
	$sql2 = mysql_query($sql);

	} ?> 

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

opa Wanderson deu um erro na linha 48 aonde você ta chamando a função.

 

esse erro = Fatal error: Call to undefined function slug() in /home/endereco-site.php on line 48

$cod = date('dmY_his') . '_' . slug($_FILES["arquivo"]["name"]); 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Você poderá usar esta função para remover a acentuação: https://pt.stackoverflow.com/questions/49645/remover-acentos-de-uma-string-em-php

 

Ou ainda colocar um nome qualquer para o arquivo usando md5 ou sha1, caso o nome do arquivo não precise ser amigável aos olhos humanos.

Compartilhar este post


Link para o post
Compartilhar em outros sites

oi Emerson,  ja fiz aqui brother deu certo usei a função para eliminar acentos.

 

aproveitando to usando esse script para cadastrar imagens em um DB mas não cadastra, envia pra pasta no servidor mas não ta enviando ao banco.

 

<?
include "../config.php";
// Flag que indica se há erro ou não
$erro = null;
// Quando enviado o formulário
if (isset($_FILES['arquivo']))
{ 
    // Configurações
    $extensoes = array(".doc", ".txt", ".pdf", ".docx", ".jpg");
    $caminho = "uploads/";
    // Recuperando informações do arquivo
    $nome = $_FILES['arquivo']['name'];
    $temp = $_FILES['arquivo']['tmp_name'];
    // Verifica se a extensão é permitida
    if (!in_array(strtolower(strrchr($nome, ".")), $extensoes)) {
		$erro = 'Extensão inválida';
	}
    // Se não houver erro
    if (!$erro) {
        // Gerando um nome aleatório para a imagem
        $nomeAleatorio = md5(uniqid(time())) . strrchr($nome, ".");
        // Movendo arquivo para servidor
        if (!move_uploaded_file($temp, $caminho . $nomeAleatorio))
            $erro = 'Não foi possível anexar o arquivo';
				
				$sql = "INSERT INTO tb_imagens_noticias (arquivos) VALUES ('$nome')";
    }
}
?>

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Em nenhum momento, no seu código, está sendo executada a query de insert.

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por AlexandreHenrique
      Olá pessoal. preciso de uma ajuda com o meu projeto de upload.
      O projeto de upload roda no IIS + Php;
      Tenho um script que ta enviando  o arquivo para o diretório correto.
      O problema é que ao tentar acessar esse arquivo via URL, o anexo não abre  e exibe a mensagem abaixo.
       

      Notei que o arquivo ao cair no DIR, ele entra sem permissões (vi em propriedades), se eu editar o mesmo alterando as permissões, ele carrega pela url do meu site.
      Quero que o arquivo enviado pelo script caia no DIR correta com as devidas permissões pra eu poder ler no navegador via URL;
       
      Já tentei resolver de toda forma mas nao tive sucesso;.
      No Apache isso é mais simples, mas no IIS ta complicado;
       
       
       
      Alguem pode me dá uma dica?
    • Por Caio Vargas
      Fala pessoa tudo tranquilo ?
      estou com um problema eu fiz um sistema de upload onde tem a marca dagua  o problema e que quando o cadastro da capa e pequena a imagem da marca dagua fica grande
      e qauando a capa e grande  a imagem da marca dagua fica pequena alguem poderia me ajudar 
    • Por mateus.andriollo
      Olá,
      Gostaria de saber se alguem pode me ajudar.
      Meu PHP esta na pasta public_html em um CPanel, quero saber se é possível armazenar em pasta fora da pasta  pública, por segurança mesmo...
      Faço isso em ASP, ai chamo a imagem por um fso, funciona mas queria saber se tem como no PHP.
    • Por DeniseAlencar
      Boar tarde pessoal estou fazendo um teste com upload de imagens gravando no banco de dados porem quando cadastro uma imagem com o nome "foto.jpg" e depois cadastro a mesma imagem com o mesmo nome, no banco de dados aparece dois registros com nomes iguais mas gostaria que os nomes fossem diferentes.
       
      E na pasta arquivos aparece uma unica imagem gostaria que quando cadastrasse fotos iguais o nome mudasse tipo foto.jpg , foto2.jpg  etc (isso automaticamente) vou postar o codigo .
      <?php $diretorio = "arquivos/"; if(!is_dir($diretorio)){ echo "Pasta $diretorio não existe";}else{ $arquivo = isset($_FILES['arquivo']) ? $_FILES['arquivo'] : FALSE; for ($controle = 0; $controle < count($arquivo['name']); $controle++){ $destino = $diretorio."/".$arquivo['name'][$controle]; $nome_foto = $arquivo['name'][$controle]; if(move_uploaded_file($arquivo['tmp_name'][$controle], $destino)){ $sql="INSERT INTO galeria (arquivo) VALUES ('$nome_foto')"; $qry = mysqli_query($conexao,$sql); echo "<head><meta HTTP-EQUIV='refresh' CONTENT='0;URL=index.php'></head>"; }else{ echo "Erro ao realizar upload"; } } } ?>  
    • Por Sapinn
      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
×

Informação importante

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