Jump to content
Matheus B. Siqueira

[ Resolvido ] Falha ao retornar dados com PDO

Recommended Posts

Meu PDO, não está retornando nenhum valor, e está dando erro ao tentar baixar o arquivo:

 

Screenshot_8.png.e2f0492a9700c44fce6edd04befff496.png

 

 

<?php
 
 //se não tiver o parametro, mata a aplicação.
 if (isset($_POST['codigo_video'])) {
    $codigo_video = $_POST['codigo_video'];
}



 //Aqui está um exemplo simples de como fazer uma conexão PDO
 $host = 'localhost';
 $db   = 'onteach';
 $user = 'root';
 $pass = 'root';
 $charset = 'utf8mb4';
 
 $dsn = "mysql:host=$host;dbname=$db;charset=$charset";

 try {
      $pdo = new PDO($dsn, $user, $pass);
 } catch (PDOException $e) {
      throw new PDOException($e->getMessage(), (int)$e->getCode());
 }

 //$pdoQuery = $pdo->query("SELECT conteudo.arquivo FROM conteudo WHERE conteudo.conteudo_video = '{$codigo_video}'");
 try{

    $ready = $pdo->prepare("SELECT conteudo.arquivo FROM conteudo WHERE conteudo.conteudo_video = :codigo_video");
    $ready->bindParam(':codigo_video', $codigo_video);

  //  $ready = $pdo->prepare($pdoQuery);
  //  $ready->execute();

 }catch(PDOException $e){
     echo $e->getMessage();
 }
 while($rs = $ready->fetch(PDO::FETCH_ASSOC));{

    $local = 'upload/';
    $local_arquivo = $local.$rs;

    header('Content-type: octet/stream');
    // Indica o nome do arquivo como será "baixado". Você pode modificar e colocar qualquer nome de arquivo
    header('Content-disposition: attachment; filename="'.$rs.'";'); 
    // Indica ao navegador qual é o tamanho do arquivo
    header('Content-Length: '.filesize($local_arquivo));
    // Busca todo o arquivo e joga o seu conteúdo para que possa ser baixado
    readfile($local_arquivo);
 }
print_r($rs);
?>

Alguém sabe resolver? Visto que o $rs não retorna o dado arquivo da tabela

Share this post


Link to post
Share on other sites

Nesta linha, você precisa passar o campo do result set.

 

//$local_arquivo = $local.$rs;
$local_arquivo = $local.$rs['arquivo'];

 

seria interessante também antes do download verificar se o arquivo existe:

 

if( file_exists($local_arquivo) ) {
	... headers e readfile
}

 

Share this post


Link to post
Share on other sites

O "problema" foi um pouco mais "fundo", contudo,

implementando as orientações de @André Severino,

segue, abaixo, possível solução:

 

CÓDIGO:

<?php

//se não tiver o parametro, mata a aplicação.
if (isset($_POST['codigo_video'])) {
    $codigo_video = $_POST['codigo_video'];
}

//Aqui está um exemplo simples de como fazer uma conexão PDO
$host = 'localhost';
$db = 'onteach';
$user = 'root';
$pass = 'root';
$charset = 'utf8mb4';

$dsn = "mysql:host=$host;dbname=$db;charset=$charset";

try {
    $pdo = new PDO($dsn, $user, $pass);
} catch (PDOException $e) {
    throw new PDOException($e->getMessage(), (int)$e->getCode());
}

//$pdoQuery = $pdo->query("SELECT conteudo.arquivo FROM conteudo WHERE conteudo.conteudo_video = '{$codigo_video}'");
try {
    $ready = $pdo->prepare("SELECT conteudo.arquivo FROM conteudo WHERE conteudo.conteudo_video = :codigo_video");
    $ready->bindParam(':codigo_video', $codigo_video);
    $ready->execute();
} catch(PDOException $e) {
    echo $e->getMessage();
}

while ($rs = $ready->fetch(PDO::FETCH_ASSOC)) {
    $local = 'upload/';
    $local_arquivo = $local.$rs['arquivo'];

    if (file_exists($local_arquivo)) {
        header('Content-type: octet/stream');
        // Indica o nome do arquivo como será "baixado". Você pode modificar e colocar qualquer nome de arquivo
        header('Content-disposition: attachment; filename="'.$rs['arquivo'].'";'); 
        // Indica ao navegador qual é o tamanho do arquivo
        header('Content-Length: '.filesize($local_arquivo));
        // Busca todo o arquivo e joga o seu conteúdo para que possa ser baixado
        readfile($local_arquivo);
    } else {
        echo "Arquivo nao existe!";
    }
}

 

Share this post


Link to post
Share on other sites
1 hora atrás, André Severino disse:

Nesta linha, você precisa passar o campo do result set.

 


//$local_arquivo = $local.$rs;
$local_arquivo = $local.$rs['arquivo'];

 

seria interessante também antes do download verificar se o arquivo existe:

 


if( file_exists($local_arquivo) ) {
	... headers e readfile
}

 

Opa andré tudo certo?

Testei como você disse porém apareceu este erro gigante aqui..

 

Screenshot_10.png.d3ec2f31a7555d8b8f95404fad71202f.png

58 minutos atrás, ShadowDLL disse:

O "problema" foi um pouco mais "fundo", contudo,

implementando as orientações de @André Severino,

segue, abaixo, possível solução:

 

CÓDIGO:


<?php

//se não tiver o parametro, mata a aplicação.
if (isset($_POST['codigo_video'])) {
    $codigo_video = $_POST['codigo_video'];
}

//Aqui está um exemplo simples de como fazer uma conexão PDO
$host = 'localhost';
$db = 'onteach';
$user = 'root';
$pass = 'root';
$charset = 'utf8mb4';

$dsn = "mysql:host=$host;dbname=$db;charset=$charset";

try {
    $pdo = new PDO($dsn, $user, $pass);
} catch (PDOException $e) {
    throw new PDOException($e->getMessage(), (int)$e->getCode());
}

//$pdoQuery = $pdo->query("SELECT conteudo.arquivo FROM conteudo WHERE conteudo.conteudo_video = '{$codigo_video}'");
try {
    $ready = $pdo->prepare("SELECT conteudo.arquivo FROM conteudo WHERE conteudo.conteudo_video = :codigo_video");
    $ready->bindParam(':codigo_video', $codigo_video);
    $ready->execute();
} catch(PDOException $e) {
    echo $e->getMessage();
}

while ($rs = $ready->fetch(PDO::FETCH_ASSOC)) {
    $local = 'upload/';
    $local_arquivo = $local.$rs['arquivo'];

    if (file_exists($local_arquivo)) {
        header('Content-type: octet/stream');
        // Indica o nome do arquivo como será "baixado". Você pode modificar e colocar qualquer nome de arquivo
        header('Content-disposition: attachment; filename="'.$rs['arquivo'].'";'); 
        // Indica ao navegador qual é o tamanho do arquivo
        header('Content-Length: '.filesize($local_arquivo));
        // Busca todo o arquivo e joga o seu conteúdo para que possa ser baixado
        readfile($local_arquivo);
    } else {
        echo "Arquivo nao existe!";
    }
}

 

Segue o outro erro apresentado acima

Share this post


Link to post
Share on other sites

Este erro ira ocorrer porque, muito provavelmente,

você está tentando fazer o Download do Arquivo

via Ajax, e até onde sei, isso é impossível...

 

Não seria mais fácil você apenas "redirecionar o

usuário" passando o ID do conteúdo como um

parâmetro GET?

 

Segue exemplo para melhor compreensão:

 

CÓDIGO [ INDEX.PHP ]

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<meta http-equiv="X-UA-Compatible" content="IE=edge">

		<title> TESTE </title>

		<link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.4.1/css/bootstrap.min.css" />
	</head>

	<body>
		<div class="container">
			<table class="table">
				<thead>
					<tr>
						<th># ID</th>
						<th># FILE</th>
						<th>#</th>
					</tr>
				</thead>

				<tbody>
				<?php
				$conn = new PDO ('mysql:host=localhost;dbname=onteach', 'root', 'root');
				$conteudo = $conn->prepare("SELECT * FROM conteudo");
				$conteudo->execute();

				while ($key = $conteudo->fetch(PDO::FETCH_OBJ)):?>
					<tr>
						<td><?= $key->idConteudo ?></td>
						<td><?= $key->arquivo ?></td>
						<td>
							<a href="download.php?id=<?= $key->conteudo_video ?>" class="btn btn-danger">
								DOWNLOAD
							</a>
						</td>
					</tr>
				<?php endwhile; ?>
				</tbody>
			</table>
		</div>
	</body>
</html>

CÓDIGO [ DOWNLOAD.PHP ]

<?php

//se não tiver o parametro, mata a aplicação.
if (isset($_GET['id'])) {
    $codigo_video = $_GET['id'];
}

//Aqui está um exemplo simples de como fazer uma conexão PDO
$host = 'localhost';
$db = 'onteach';
$user = 'root';
$pass = 'root';
$charset = 'utf8mb4';

$dsn = "mysql:host=$host;dbname=$db;charset=$charset";

try {
    $pdo = new PDO($dsn, $user, $pass);
} catch (PDOException $e) {
    throw new PDOException($e->getMessage(), (int)$e->getCode());
}

//$pdoQuery = $pdo->query("SELECT conteudo.arquivo FROM conteudo WHERE conteudo.conteudo_video = '{$codigo_video}'");
try {
    $ready = $pdo->prepare("SELECT conteudo.arquivo FROM conteudo WHERE conteudo.conteudo_video = :codigo_video");
    $ready->bindParam(':codigo_video', $codigo_video);
    $ready->execute();
} catch(PDOException $e) {
    echo $e->getMessage();
}

while ($rs = $ready->fetch(PDO::FETCH_ASSOC)) {
    $local = 'upload/';
    $local_arquivo = $local.$rs['arquivo'];

    if (file_exists($local_arquivo)) {
        header('Content-type: octet/stream');
        // Indica o nome do arquivo como será "baixado". Você pode modificar e colocar qualquer nome de arquivo
        header('Content-disposition: attachment; filename="'.$rs['arquivo'].'";'); 
        // Indica ao navegador qual é o tamanho do arquivo
        header('Content-Length: '.filesize($local_arquivo));
        // Busca todo o arquivo e joga o seu conteúdo para que possa ser baixado
        readfile($local_arquivo);
    } else {
        echo "Arquivo nao existe!";
    }
}

 

Vale a pena ressaltar que os códigos acima são

apenas exemplos, sendo assim, podendo existir

abordagens melhores que as utilizadas...

 

Share this post


Link to post
Share on other sites

@Matheus B. Siqueira tente esse script meu:

https://github.com/Spell-Master/sm-web/tree/master/javascript/FileTransfer

 

Basta informar local, nome do arquivo com sua extensão assim como eu transcrevi no exemplo:

No caso fora do laço de repetição do while

if (file_exists($local_arquivo)) {
?>
    <script>
      file = new FileTransfer();
      file.download('<?= $local_arquivo ?>', true);
    </script>
<?php
}

 

 

 

Share this post


Link to post
Share on other sites
24 minutos atrás, ShadowDLL disse:

Este erro ira ocorrer porque, muito provavelmente,

você está tentando fazer o Download do Arquivo

via Ajax, e até onde sei, isso é impossível...

 

Não seria mais fácil você apenas "redirecionar o

usuário" passando o ID do conteúdo como um

parâmetro GET?

 

Segue exemplo para melhor compreensão:

 

CÓDIGO [ INDEX.PHP ]


<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<meta http-equiv="X-UA-Compatible" content="IE=edge">

		<title> TESTE </title>

		<link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.4.1/css/bootstrap.min.css" />
	</head>

	<body>
		<div class="container">
			<table class="table">
				<thead>
					<tr>
						<th># ID</th>
						<th># FILE</th>
						<th>#</th>
					</tr>
				</thead>

				<tbody>
				<?php
				$conn = new PDO ('mysql:host=localhost;dbname=onteach', 'root', 'root');
				$conteudo = $conn->prepare("SELECT * FROM conteudo");
				$conteudo->execute();

				while ($key = $conteudo->fetch(PDO::FETCH_OBJ)):?>
					<tr>
						<td><?= $key->idConteudo ?></td>
						<td><?= $key->arquivo ?></td>
						<td>
							<a href="download.php?id=<?= $key->conteudo_video ?>" class="btn btn-danger">
								DOWNLOAD
							</a>
						</td>
					</tr>
				<?php endwhile; ?>
				</tbody>
			</table>
		</div>
	</body>
</html>

CÓDIGO [ DOWNLOAD.PHP ]


<?php

//se não tiver o parametro, mata a aplicação.
if (isset($_GET['id'])) {
    $codigo_video = $_GET['id'];
}

//Aqui está um exemplo simples de como fazer uma conexão PDO
$host = 'localhost';
$db = 'onteach';
$user = 'root';
$pass = 'root';
$charset = 'utf8mb4';

$dsn = "mysql:host=$host;dbname=$db;charset=$charset";

try {
    $pdo = new PDO($dsn, $user, $pass);
} catch (PDOException $e) {
    throw new PDOException($e->getMessage(), (int)$e->getCode());
}

//$pdoQuery = $pdo->query("SELECT conteudo.arquivo FROM conteudo WHERE conteudo.conteudo_video = '{$codigo_video}'");
try {
    $ready = $pdo->prepare("SELECT conteudo.arquivo FROM conteudo WHERE conteudo.conteudo_video = :codigo_video");
    $ready->bindParam(':codigo_video', $codigo_video);
    $ready->execute();
} catch(PDOException $e) {
    echo $e->getMessage();
}

while ($rs = $ready->fetch(PDO::FETCH_ASSOC)) {
    $local = 'upload/';
    $local_arquivo = $local.$rs['arquivo'];

    if (file_exists($local_arquivo)) {
        header('Content-type: octet/stream');
        // Indica o nome do arquivo como será "baixado". Você pode modificar e colocar qualquer nome de arquivo
        header('Content-disposition: attachment; filename="'.$rs['arquivo'].'";'); 
        // Indica ao navegador qual é o tamanho do arquivo
        header('Content-Length: '.filesize($local_arquivo));
        // Busca todo o arquivo e joga o seu conteúdo para que possa ser baixado
        readfile($local_arquivo);
    } else {
        echo "Arquivo nao existe!";
    }
}

 

Vale a pena ressaltar que os códigos acima são

apenas exemplos, sendo assim, podendo existir

abordagens melhores que as utilizadas...

 

Entendi amigo, vou tentar assim, naquela parte "

<?= $key->conteudo_video ?>"

 

 

Como eu faço para ele puxar o valor do select?, como exemplo assim:

 

        <select name="conteudo" id="conteudo">
        </select>
 
//no jquery
var codigoVideo = $("#conteudo").val();

Share this post


Link to post
Share on other sites

Aparece Undefined Index conteudo:

 

  <?php
        $codigo_video = $_POST['conteudo'];
        $conn = new PDO ('mysql:host=localhost;dbname=onteach''root''root');
        $conteudo = $conn->prepare("SELECT * FROM conteudo WHERE conteudo.conteudo_video = '$codigo_video'");
        $conteudo->execute();
 
        while ($key = $conteudo->fetch(PDO::FETCH_OBJ)):?>
 
   <button href="baixar_arquivo.php?id=<?= $key->conteudo_video ?>" type="button" id="baixar_ctt" class="btn btn-secondary btn-sm" data-dismiss="modal">Baixar material</button></div>
   <?php endwhile?>
   

Share this post


Link to post
Share on other sites

Vamos lá,

 

Primeiro, antes de lhe mostrar um exemplo, poderia

enviar o código onde você seleciona o item que

deseja fazer o download?

Share this post


Link to post
Share on other sites

Claro https://pastebin.com/RYs5S36q

 

Lembrando que os valores que coloca no main.js, definem os options, que no fim, definem o valor do select que seria o campo que teria que baixar o arquivo

52 minutos atrás, ShadowDLL disse:

Vamos lá,

 

Primeiro, antes de lhe mostrar um exemplo, poderia

enviar o código onde você seleciona o item que

deseja fazer o download?

 

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

  • Similar Content

    • By Negrito
      Olá Pessoal, 
       
      Converti o banco de dados de uma app em ASP Classico de MSSQL para MySQL para redução de custos e percebi que alguns componentes ou recursos não estão mais funcionando devido a não compatibilidade com o MySQL , como por exemplo a função : RecordCount
       
      Já consegui converter e atualizar 95% de aplicação para rodar com o MySQL, mas tem 1 item que esta tirando meu sono e após dias pesquisando, resolvi pedir ajuda.
       
      Segue o meu codigo abaixo , onde estou com problema no resultado dessa operação:
       
      <%
      ...
      Set RS = Server.CreateObject("ADODB.Recordset")
      RS.CursorLocation = 3
      RS.CursorType = 3
      RS.ActiveConnection = Cn
      RS.Open strSQL, Cn, 3, 3
      RS.PageSize = 25
      RS.CacheSize = RS.PageSize
      intPageCount = RS.PageCount
      intRecordCount = RS.RecordCount
          If NOT (RS.BOF AND RS.EOF) Then
      If CInt(intPage) > CInt(intPageCount) Then intPage = intPageCount
          If CInt(intPage) <= 0 Then intPage = 1
              If intRecordCount > 0 Then
                  RS.AbsolutePage = intPage
                  intStart = RS.AbsolutePosition
                  If CInt(intPage) = CInt(intPageCount) Then
                      intFinish = intRecordCount
                  Else
                      intFinish = intStart + (RS.PageSize - 1)
                  End if
              End If
          If intRecordCount > 0 Then
              For intRecord = 1 to RS.PageSize
          QntExibicoes = QntExibicoes + Rs.fields("views")
      ...
      %>
       
       
      Já percebi que a função RecordCount não pode ser usada com o MySQL ou pelo menos não é compativel.
       
      A paginação esta funcionando ! 
      Porem , não consigo fazer ele calcular a quantidade de linhas (rows) do MySQL com a função RecordCount e acredito que possa ter alguma outra função que não esta compativel , mas como não conheço MySQL , não posso afirmar.
       
      Enfim, algum pode me dar uma luz ?
       
      Desde já agradeço pela atenção.
       
      Obrigado.
    • By Marcos RJ
      Bom dia, boa tarde, boa noite colegas.
       
      Tenho um projeto onde conterá diversos subdomínios. Ex.:
      empresa1.site.com.br empresa2.site.com.br empresa3.site.com.br Esses subdomínios acessarão o sistema que está dentro do seguinte diretório:
      site.com.br/sistema/ Gostaria de fazer com que os subdomínios acessassem o sistema sem alterar a url, pois o objetivo é quando fizer quaisquer alterações e/ou inclusões de novos recursos, não tenhamos a necessidade de fazer isso dentro de todos os subdomínios, haja vista que serão dezenas ou até mesmo centenas de subdomínios. As minhas tentativas foram diretamente no .htaccess:
      RewriteEngine on RewriteCond %{HTTP_HOST} ^empresa1.site.com$ [OR] RewriteCond %{HTTP_HOST} ^www.empresa1.site.com$ RewriteRule ^(.*) http://www.site.com/sistema/$1?key=empresa1 [P,L] E o PHP ficou dessa forma:
       
      $diretorio = $_REQUEST["key"]; if($directory != null){    require "http://".$diretorio.".site.com.br/sistema/class/conectCass.php"; }else{  require "conectClass.php";  } Mas não deu certo. Tentei diretamente pelo PHP, mas quando clico no link criado, ele me obriga que a página do link esteja dentro dos subdiretórios. Em cada subdomínio coloquei da seguinte forma:
      include 'sistema/'; E no index.php do diretório sistema/:
      $host = $_SERVER['SERVER_NAME']; $host = str_replace(['www.', '.site.com.br', 'site.com.br'], '', $host); if($host == '') {     // entra o conteúdo do sistema } else {     // Entra o conteúdo do subdomínio } Mas também não funcionou. Como eu poderia resolver isso?

      Muito obrigado!
    • By klasss
      Olá a todos, 

      Gostaria de saber se alguem conhece um layout para efetuar o registo de folha de ponto. 

      Algo do género :  Mês - Dias do mês em questão - Possibilidade de colocar as horas trabalhadas. 

      Deixo uma imagem de exemplo. 
      Obrigado!
       

    • By b2black
      Quando preencho o cadastro e clico em cadastrar, a informação não é salva no banco de dados, e também, como pode ver na imagem action2, as informações digitadas permanecem nos campos imput e o nome vai para o alerta de erro de mensagem em baixo do campo....
       
      <?php require_once "config.php"; $idclient = $fullname = $cpfclient = $gender = $phone = $email = $dayagend = $houragend = ""; $idclient_err = $fullname_err = $cpfclient_err = $gender_err = $phone_err = $email_err = $dayagend_err = $houragend_err = ""; if($_SERVER["REQUEST_METHOD"] == "POST"){ // $input_idclient = trim($_POST["idclient"]); if(empty($input_idclient)){ $idclient_err = "ID de identificação do cliente."; } else{ $idclient = $input_idclient; } $input_fullname = trim($_POST["fullname"]); if(empty($input_fullname)){ $fullname_err = "Por favor, insira o nome completo do cliente."; /*} elseif(!filter_var($input_fullname, FILTER_VALIDATE_REGEXP, array("options"=>array("regexp"=>"/^[a-zA-Z\s]+$/")))){ $fullname_err = "Por favor, insira um nome válido de cliente.";*/ } else{ $fullname = $input_fullname; } $input_cpfclient = trim($_POST["cpfclient"]); if(empty($input_cpfclient)){ $cpfclient_err = "Por favor, insira o CPF do cliente."; } elseif(!ctype_digit($input_cpfclient)){ $cpfclient_err = "Por favor, coloque apenas números do CPF."; } else{ $cpfclient = $input_cpfclient; } $input_gender = trim($_POST["gender"]); if(empty($input_gender)){ $gender_err = "Por favor, escolha o gênero do cliente."; } else{ $gender = $input_gender; } $input_phone = trim($_POST["phone"]); if(empty($input_phone)){ $phone_err = "Por favor, insira o telefone do cliente."; } elseif(!ctype_digit($input_phone)){ $phone_err = "Por favor, é necessário inserir o telefone de contato do cliente."; } else{ $phone = $input_phone; } $input_email = trim($_POST["email"]); if(empty($input_email)){ $email_err = "Por favor, insira o e-mail do cliente."; } else{ $email = $input_email; } $input_dayagend = trim($_POST["dayagend"]); if(empty($input_dayagend)){ $dayagend_err = "Por favor, coloque a data do atendimento do cliente."; } elseif(!ctype_digit($input_dayagend)){ $dayagend_err = "Por favor, é necessário uma data de atendimento para o cliente."; } else{ $dayagend = $input_dayagend; } $input_houragend = trim($_POST["houragend"]); if(empty($input_houragend)){ $houragend_err = "Por favor, coloque a data do atendimento do cliente."; } elseif(!ctype_digit($input_houragend)){ $houragend_err = "Por favor, é necessário uma data de atendimento para o cliente."; } else{ $houragend = $input_houragend; } if(empty($idclient) && empty($fullname_err) && empty($cpfclient_err)&& empty($gender_err)&& empty($phone_err)&& empty($email_err)&& empty($dayagend_err)&& empty($houragend_err)){ $sql = "INSERT INTO schedule (idclient, fullname, cpfclient, gender, phone, email, dayagend, houragend) VALUES (?, ?, ?)"; if($stmt = mysqli_prepare($link, $sql)){ mysqli_stmt_bind_param($stmt, "sss", $param_idclient, $param_fullname, $param_cpfclient, $param_gender, $param_phone, $param_email, $param_dayagend, $param_houragend); $param_idclient = $idclient; $param_fullname = $fullname; $param_cpfclient = $cpfclient; $param_gender = $gender; $param_phone = $phone; $param_email = $email; $param_dayagend = $dayagend; $param_houragend = $houragend; if(mysqli_stmt_execute($stmt)){ header("location: index.php"); exit(); } else{ echo "Ops! Algo deu errado. Por favor, tente novamente mais tarde."; } } if($stmt = mysqli_prepare($link, $sql)){ // [...] mysqli_stmt_close($stmt); } } mysqli_close($link); } ?> <!DOCTYPE html> <html lang="pt-br"> <head> <meta charset="UTF-8"> <title>Agenda dos Clientes</title> <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.5.2/css/bootstrap.min.css"> <style> .wrapper{ width: 600px; margin: 0 auto; } </style> </head> <body> <div class="wrapper"> <div class="container-fluid"> <div class="row"> <div class="col-md-12"> <h2 class="mt-5">Cadastro do Cliente</h2> <p>Por favor, preencha os campos abaixos para agendar o cliente.</p> <form action="<?php echo htmlspecialchars($_SERVER["PHP_SELF"]); ?>" method="post"> <div class="form-group"> <label>ID DO CLIENTE</label> <input type="text" name="idclient" class="form-control <?php echo (!empty($idclient_err)) ? 'is-invalid' : ''; ?>" value="<?php echo $idclient; ?>"> <span class="invalid-feedback"><?php echo $idclient_err;?></span> </div> <div class="form-group"> <label>NOME COMPLETO</label> <input type="text" name="fullname" class="form-control <?php echo (!empty($fullname_err)) ? 'is-invalid' : ''; ?>"><?php echo $fullname; ?> <span class="invalid-feedback"><?php echo $fullname_err;?></span> </div> <div class="form-group"> <label>CPF</label> <input type="text" name="cpfclient" class="form-control <?php echo (!empty($cpfclient_err)) ? 'is-invalid' : ''; ?>" value="<?php echo $cpfclient; ?>"> <span class="invalid-feedback"><?php echo $cpfclient_err;?></span> </div> <div class="form-group"> <label>GÊNERO</label> <input type="text" name="gender" class="form-control <?php echo (!empty($gender_err)) ? 'is-invalid' : ''; ?>" value="<?php echo $gender; ?>"> <span class="invalid-feedback"><?php echo $gender_err;?></span> </div> <div class="form-group"> <label>Telefone</label> <input type="text" name="phone" class="form-control <?php echo (!empty($phone_err)) ? 'is-invalid' : ''; ?>" value="<?php echo $phone; ?>"> <span class="invalid-feedback"><?php echo $phone_err;?></span> </div> <div class="form-group"> <label>E-mail</label> <input type="text" name="email" class="form-control <?php echo (!empty($email_err)) ? 'is-invalid' : ''; ?>" value="<?php echo $email; ?>"> <span class="invalid-feedback"><?php echo $email_err;?></span> </div> <div class="form-group"> <label>Agendar Dia</label> <input type="text" name="dayagend" class="form-control <?php echo (!empty($dayagend_err)) ? 'is-invalid' : ''; ?>" value="<?php echo $dayagend; ?>"> <span class="invalid-feedback"><?php echo $dayagend_err;?></span> </div> <div class="form-group"> <label>Agendar Horário</label> <input type="text" name="houragend" class="form-control <?php echo (!empty($houragend_err)) ? 'is-invalid' : ''; ?>" value="<?php echo $houragend; ?>"> <span class="invalid-feedback"><?php echo $houragend_err;?></span> </div> <input type="submit" class="btn btn-primary" value="Submit"> <a href="index.php" class="btn btn-secondary ml-2">Cancel</a> </form> </div> </div> </div> </div> </body> </html>  


    • By Air-Gear
      Olá, na parte de enviar eu conseguir, mas manter até terminar o cadastro eu não conseguir. Eu vou contar toda a história para ficar mais claro possível.
       
      Eu precisei implementar um Upload de qualquer imagem ou PDF na página de solicitar compras. O site utiliza AngularJS, a primeira versão do Angular. Eu tentei fazer sem depender de PHP, mas na internet achava só a parte de Front-End e ninguém sabia fazer no Back-End. Então eu resolvi fazer com PHP mesmo.
       
      Nó código PHP, ele aceita todos as extensões de imagens mais o PDF e é possível envia-los todos de uma vez na quantidade que quiser. Todos os arquivos serão renomeados, contendo no nome o ID do usuário logado pego pela função javascript, o dia do mês, o mês, o ano, o dia da semana, a hora, o minuto, o segundo, se é AM ou PM e uma numeração aleatório. O arquivo PDF vai continuar sendo PDF e todas as imagens serão JPG. No final, todos serão enviados para uma pasta chamada upload.
       
      Só que agora eu preciso jogar de volta para página para salvar os novos nomes dos arquivos para continuar o cadastro da solicitação de compras. Como AngularJS utiliza Javascript, eu tentei usa-lo dentro do PHP utilizando EOF, mas não tive resultado. Eu só consigo com HTML com as diretivas do AngularJS. Na parte do API, nos atributos, eu declarei "nomeArquivo: []," , para salvar os nomes dos arquivos.
       
      Seguem o código.
      <div class="row"> <div class="col-sm-12 col-md-6 "> <div class="upload_form_cont"> <form id="upload_form" enctype="multipart/form-data" method="post" action="/profile-upload"> <div> <div><label for="image_file">Selecione o arquivo de imagem</label></div> <div><input type="file" name="image_file" id="image_file" accept="image/*" onchange="fileSelected();" /></div> </div> <div> <input type="button" value="Upload" onclick="startUploading()" /> </div> <div id="fileinfo"> <div id="filename"></div> <div id="filesize"></div> <div id="filetype"></div> <div id="filedim"></div> </div> <div id="error">Você deve selecionar apenas arquivos de imagem válidos!</div> <div id="error2">Ocorreu um erro ao enviar o arquivo</div> <div id="abort">O upload foi cancelado pelo usuário ou o navegador interrompeu a conexão</div> <div id="warnsize">Seu arquivo é muito grande. Não podemos aceitar isso. Selecione arquivos pequenos</div> <div id="progress_info"> <div id="progress"></div> <div id="progress_percent">&nbsp;</div> <div class="clear_both"></div> <div> <div id="speed">&nbsp;</div> <div id="remaining">&nbsp;</div> <div id="b_transfered">&nbsp;</div> <div class="clear_both"></div> </div> <div id="upload_response"></div> </div> </form> </div> </div> </div> upload.php
      <?php function bytesToSize1024($bytes, $precision = 2) { $unit = array('B','KB','MB'); return @round($bytes / pow(1024, ($i = floor(log($bytes, 1024)))), $precision).' '.$unit[$i]; } //Pega o id do usuário logado $id_url = $_GET['id']; // Numero de campos de upload $numeroCampos = count($_FILES['image_file']['name']); // Tamanho máximo do arquivo (em bytes) $tamanhoMaximo = 1024*1024*2; // Extensões aceitas $extensoes = array(".jpg", "jpeg", ".gif", ".png", ".pdf", ".bmp", ".pdf", ".tiff"); //Local da pasta $_UP['pasta'] = '../upload/'; $substituir = false; for ($i = 0; $i < $numeroCampos; $i++) { // Informações do arquivo enviado $sFileName = $_FILES['image_file']['name'][$i]; $sSize = $_FILES['image_file']['size'][$i]; $sFileSize = bytesToSize1024($sSize, 1); $nomeTemporario = $_FILES['image_file']['tmp_name'][$i]; // Verifica se o arquivo foi colocado no campo if (!empty($sFileName)) { $erro = false; // Verifica se o tamanho do arquivo é maior que o permitido if ($sSize > $tamanhoMaximo) { $erro = "O arquivo " . $sFileName . " não deve ultrapassar " . $tamanhoMaximo. " bytes"; } // Verifica se a extensão está entre as aceitas elseif (!in_array(strrchr($sFileName, "."), $extensoes)) { $erro = "A extensão do arquivo <b>" . $sFileName . "</b> não é válida"; } // Verifica se o arquivo existe e se é para substituir elseif (file_exists($_UP['pasta'] . $sFileName) and !$substituir) { $erro = "O arquivo <b>" . $sFileName . "</b> já existe"; } else{ //Pega a extensão do arquivo $TipoExtensao = pathinfo($sFileName, PATHINFO_EXTENSION); // O arquivo passou em todas as verificações, hora de tentar movê-lo para a pasta // Primeiro verifica se deve trocar o nome do arquivo $unixTime = time(); $timeZone = new \DateTimeZone('America/Sao_Paulo'); $time = new \DateTime(); $time->setTimestamp($unixTime)->setTimezone($timeZone); $formattedTime = $time->format('d-m-Y_l_h-i-s-a'); $aleatorio = rand(); if($TipoExtensao == 'pdf'){ $nome_final = $id_url .'_'. $formattedTime .'_'. $aleatorio .'.pdf'; }else{ $nome_final = $id_url .'_'. $formattedTime .'_'. $aleatorio .'.jpg'; } // Depois verifica se é possível mover o arquivo para a pasta escolhida if (move_uploaded_file($nomeTemporario, $_UP['pasta'] . $nome_final)) { // Upload efetuado com sucesso, exibe uma mensagem e um link para o arquivo echo "Upload do arquivo ".$sFileName." foi efetuado com sucesso!"; echo "</br>"; echo<<<EOF <p>Eu tentei implementar o retorno da página aqui!</p> <p></br></p> <p></br></p> EOF; } else { // Não foi possível fazer o upload, provavelmente a pasta está incorreta echo "Não foi possível enviar o arquivo, tente novamente"; echo "</br>"; } } } else { echo "Selecione algum arquivo de imagem ou PDF para fazero upload."; } } ?>  
×

Important Information

Ao usar o fórum, você concorda com nossos Terms of Use.