Ir para conteúdo

Arquivado

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

brunowdesigner

Sistema de Upload por Usuário

Recommended Posts

Olá Pessoal. Boa noite.

Sou novo aqui no fórum e também estou começando agora a programar.

 

Então, estou desenvolvendo pra um cliente um sistema administrativo onde ele vai cadastrar, editar e excluir clientes.

Nesse sistema administrativo ele também quer ter uma opção de enviar arquivos (pdf e docx) para cada cliente.

Assim que cada cliente acessar a sua área administrativa aparecerá os respectivos documentos.

 

1.png?1456889192

 

O sistema de upload está feito, só não estou conseguindo selecionar o usuário e cadastrar o arquivo no banco de dados, pra depois cada cliente listar seus documentos.

 

Abaixo está o Código:

<?php
// DEFINIÇÕES
// Numero de campos de upload
$numeroCampos = 5;
// Tamanho máximo do arquivo (em bytes)
$tamanhoMaximo = 1000000;
// Extensões aceitas
$extensoes = array(".doc", ".txt", ".pdf", ".docx");
// Caminho para onde o arquivo será enviado
$caminho = "uploads/";
// Substituir arquivo já existente (true = sim; false = nao)
$substituir = false;
 
for ($i = 0; $i < $numeroCampos; $i++) {
  
  // Informações do arquivo enviado
  $nomeArquivo = $_FILES["arquivo"]["name"][$i];
  $tamanhoArquivo = $_FILES["arquivo"]["size"][$i];
  $nomeTemporario = $_FILES["arquivo"]["tmp_name"][$i];
  
  // Verifica se o arquivo foi colocado no campo
  if (!empty($nomeArquivo)) {
  
    $erro = false;
  
    // Verifica se o tamanho do arquivo é maior que o permitido
    if ($tamanhoArquivo > $tamanhoMaximo) {
      $erro = "O arquivo " . $nomeArquivo . " não deve ultrapassar " . $tamanhoMaximo. " bytes";
    } 
    // Verifica se a extensão está entre as aceitas
    elseif (!in_array(strrchr($nomeArquivo, "."), $extensoes)) {
      $erro = "A extensão do arquivo <b>" . $nomeArquivo . "</b> não é válida";
    } 
    // Verifica se o arquivo existe e se é para substituir
    elseif (file_exists($caminho . $nomeArquivo) and !$substituir) {
      $erro = "O arquivo <b>" . $nomeArquivo . "</b> já existe";
    }
  
    // Se não houver erro
    if (!$erro) {
      // Move o arquivo para o caminho definido
      move_uploaded_file($nomeTemporario, ($caminho . $nomeArquivo));
      
      // Mensagem de sucesso
      echo "O arquivo <b>".$nomeArquivo."</b> foi enviado com sucesso. <br />";
    } 
    // Se houver erro
    else {
      // Mensagem de erro
      echo $erro . "<br />";
    }
  }
}
?>

<?php
$query = mysql_query("SELECT nome FROM usuarios");
?>  

<form method="post" action="<?php echo $_SERVER['PHP_SELF'] ?>" enctype="multipart/form-data">
	<select>
 <option>Selecione o Cliente</option>
 
 <?php while($cliente = mysql_fetch_array($query)) { ?>
 <option value="<?php echo $cliente['nome'] ?>"><?php echo $cliente['nome'] ?></option>
 <?php } ?>
 
 </select>
  <label>Arquivos</label>
  <input type="file" name="arquivo[]" /><br>
  <input type="file" name="arquivo[]" /><br>
  <input type="file" name="arquivo[]" /><br>
  <input type="file" name="arquivo[]" /><br>
  <input type="file" name="arquivo[]" /><br>
  
  <input type="submit" value="Enviar" />
</form>

Compartilhar este post


Link para o post
Compartilhar em outros sites

Seu código está funcionando, você apenas esqueceu de dar um require_once no seu arquivo de conexão com o banco de dados =D

coloque no inicio do php:

require_once 'conexao.php'; // nome do seu arquivo de conexão XD

Compartilhar este post


Link para o post
Compartilhar em outros sites

 

Seu código está funcionando, você apenas esqueceu de dar um require_once no seu arquivo de conexão com o banco de dados =D

 

coloque no inicio do php:

require_once 'conexao.php'; // nome do seu arquivo de conexão XD

 

Verdade.

Mas ele não está inserindo o nome do arquivo para o cliente selecionado.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Ele não está inserindo porque não existe nenhuma insert into no seu código...

Compartilhar este post


Link para o post
Compartilhar em outros sites

Ele não está inserindo porque não existe nenhuma insert into no seu código...

é ai que ta o problema .. não to conseguindo inserir. Quero pegar o nome do arquivo e inserir no usuário selecionado.

Compartilhar este post


Link para o post
Compartilhar em outros sites

@BlackMix o primeiro resultado da busca vem em Mysql (w3school)

 

Rapaz.

acabei me atrapalhando pra fazer o exemplo se acredita?! hsauhsaua

Apanhei mas fiz algo que ficou bem clean.

se liga:

<?php
if($_POST){
	// var_dump($_POST);die()
	// print_r($_FILES['arquivo']);die();
	$cliente_id = $_POST['cliente'];
	
	####Dentro do $_FILES vem essa galera:
	# name
	# type
	# tmp_name
	# error
	# size
	
	for($i = 0; $i < count($_FILES['arquivo']); $i++){
		if ($_FILES['arquivo']['error'][$i] == UPLOAD_ERR_OK) {
			
			$name 		 = $_FILES['arquivo']['name'][$i];
			$tmp_name 	 = $_FILES['arquivo']['tmp_name'][$i];
			$uploads_dir = './uploads';
			
			move_uploaded_file($tmp_name, "{$uploads_dir}/{$name}");
			
			//Logica do insert vem aqui...
		
		}
		
	}
	
	
	

	
}


?><!DOCTYPE HTML>
<html lang="pt-BR">
<head>
	<meta charset="UTF-8">
	<title></title>
</head>
<body>

<form method="post" action="<?php echo $_SERVER['PHP_SELF'] ?>" enctype="multipart/form-data">

	<?php 
		//Criando o nosso 'banco'
		$clientes = array(
			array(
				'id' 	=> 1
				,'nome' 	=> 'José'
			)
			,array(
				'id' 	=> 2
				,'nome' 	=> 'Maria'
			)
			,array(
				'id' 	=> 3 
				,'nome' 	=> 'Beraldo'
			)
		);
	?>
	
	
	<select name="cliente">
		<option value="">Selecione o Cliente</option>
		
		<?php foreach($clientes as $cliente): ?>
			<?php echo "<option value='". $cliente['id'] ."'>". $cliente['nome'] ."</option>";?>
		<?php endforeach; ?>
	</select>
  
  
  <h3>Arquivos:</h3>
  <input type="file" name="arquivo[]" /><br>
  <input type="file" name="arquivo[]" /><br>
  <input type="file" name="arquivo[]" /><br>
  <input type="file" name="arquivo[]" /><br>
  <input type="file" name="arquivo[]" /><br>
  <hr />
  <input type="submit" value="Enviar" />
</form>
</body>
</html>

AI as validações de extensão, você encaixa dentro do loop ( for ) ali e o insert também.

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por landerbadi
      Boa tarde pessoal. Estou tentado fazer uma consulta no banco de dados porém estou tendo dificuldades. Tenho uma tabela chamada "itens" com os seguintes campos: id, item, ativo. Nela tem cadastrado vários itens. No campo ativo eu coloco a letra "S" para informar que este item está ativo no sistema. Por exemplo: 1, casa, S 2, mesa, S 3, cama, S 4, moto S 5, rádio O quinto registro "radio" não está ativo no sistema pois não tem um "S" no campo ativo. E outra tabela chamada "produtos" com os seguintes campos (id, item1, item2, item3) com os seguintes registros: 1, casa, mesa, moto 2, mesa, casa, cama 3, rádio, cama, mesa Eu preciso fazer uma busca na tabela produtos da seguinte maneira: Eu escolho um registro na tabela "itens", por exemplo "mesa". Preciso fazer com que o php me liste todos os registros da tabela "produtos" que contenham a palavra "mesa". Até aqui tudo bem eu consigo listar. Estou fazendo assim: <?php $item = "mesa" $sql = mysqli_query($conn, "SELECT * FROM produtos WHERE item1 LIKE '$item' OR item2 LIKE '$item' OR item3 LIKE '$item' LIMIT 10"); while($aux = mysqli_fetch_assoc($sql)) { $id = $aux["id"]; $item1 = $aux["item1"]; $item2 = $aux["item2"]; $item3 = $aux["item3"]; echo $id . " - " . $item1 . ", " . $item2 . ", " $item3 . "<br>"; } ?> O problema é que está listando todos os registros que contém o item mesa. Eu preciso que o php verifique os demais item e me liste somente os registro em que todos os registros estejam ativos no sistema. No exemplo acima ele não deveria listar o registro 3. pois nesse registro contém o item "radio" e este item não está ativo no sistema. Ou seja, o registro "radio" na tabela itens não possui um "S" na coluna "ativo". Alguém sabe como resolver isso?
    • Por ILR master
      Fala galera.
      Espero que todos estejam bem.
      Seguinte: Tenho um arquivo xml onde alguns campos estão com : (dois pontos), como o exemplo abaixo:
       
      <item>
      <title>
      d sa dsad sad sadasdas
      </title>
      <link>
      dsadas dsa sad asd as dsada
      </link>
      <pubDate>sadasdasdsa as</pubDate>
      <dc:creator>
      d sad sad sa ad as das
      </dc:creator>
      </item>
       
      Meu código:
       
      $link = "noticias.xml"; 
      $xml = simplexml_load_file($link); 
      foreach($xml -> channel as $ite) {     
           $titulo = $ite -> item->title;
           $urltitulo = $ite -> item->link;
           print $urltitulo = $ite -> item->dc:creator;
      } //fim do foreach
      ?>
       
      Esse campo dc:creator eu não consigo ler. Como faço?
       
      Agradeço quem puder me ajudar.
       
      Abs
       
       
    • Por First
      Olá a todos!
       
      Eu estou criando um sistema do zero mas estou encontnrando algumas dificuldades e não estou sabendo resolver, então vim recorrer ajuda de vocês.
      Aqui está todo o meu código: https://github.com/PauloJagata/aprendizado/
       
      Eu fiz um sistema de rotas mas só mostra o conteúdo da '/' não sei porque, quando eu tento acessar o register nada muda.
      E eu também quero que se não estiver liberado na rota mostra o erro de 404, mas quando eu tento acessar um link inválido, nada acontece.
      Alguém pode me ajudar com isso? E se tiver algumas sugestão para melhoria do código também estou aceitando.
       
       
      Desde já, obrigado.
×

Informação importante

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