Jump to content
Sign in to follow this  
mistercs

Formulário com Redirecionamento

Recommended Posts

Olá Prezados,

Tenho um formulário em PHP, pequeno, no qual ele envia a função de um sistema ao e-mail do cliente, mais preciso fazer este formulário além de enviar as informações por e-mail, após o cliente clicar no botão "SOLICITAR", ele ser redirecionado para uma página de agradecimento que ficaria desta forma (www.meusite.com.br/agradecimento)

Esta página de agradecimento, será criada a partir do Wordpress, então eu preciso redirecionar direto ao LINK dela, e não ao arquivo dela, segue abaixo código que estou utilizando no formulário atualmente.

Desde já agradeço!

<?php header('Content-Type: text/html; charset=utf-8'); ?>
<?php
require("config.php");
require("includes/debug.php");
require("includes/functions.php");

//historico de url referencia

$_SESSION['URL_REFERER'][] = isset($_SERVER['HTTP_REFERER']) ? $_SERVER['HTTP_REFERER'] : null;

$r = isset($_GET['r']) ? $_GET['r'] : null;

if (null === $r) {

exit();
}

$id_revenda = (int) dpt(base64_url_decode($r), $s);

if (checkar_permissao_rev($id_revenda, "11") === false) {

exit();
}

//informações da revenda

$dados_rev = dados_revenda($id_revenda, 'level');

$titulo = 'Formulário de Pedidos de Testes';

//perfis disponiveis

if ($dados_rev['level'] == '1') {

$perfis_disp = perfis_disponiveis_revenda($id_revenda);
} else {

$perfis_disp = perfis_disponiveis_adm();
}


$config_salvo = config_painel('tempo_login_teste,mult_perf,id_modelo_padrao');

// quando o formulario for enviado

if (count($_POST) > 0) {

$nome = $_POST['nome'];
$email = $_POST['email'];
$perfis = isset($_POST['perfil']) ? $_POST['perfil'] : null;

if (is_null($nome) || $nome === "") {

$javascript = <<<EOF
<script charset="UTF-8">
alert('Preencha o campo de nome corretamente.');
window.history.go(-1);
</script>
EOF;
exit($javascript);
}

if (filter_var($email, FILTER_VALIDATE_EMAIL) === false) {

$javascript = <<<EOF
<script charset="UTF-8">
alert('Preencha o campo de email corretamente.');
window.history.go(-1);
</script>
EOF;
exit($javascript);
}

// verifica se já existe um teste pedido 

$teste_existente = check_teste_pedido($email);

if (!empty($teste_existente)) {

$data_cad = date('d/m/Y', strtotime($teste_existente['data_cad']));

$javascript = <<<EOF
<script charset="UTF-8">
alert('Existe um teste pra este email cadastrado em: {$data_cad}');
window.history.go(-1);
</script>
EOF;
exit($javascript);
}

$lista_negra = listaNegra($email);

//verifica se o dominio do email tá na lista negra
if ($lista_negra === true) {

$javascript = <<<EOF
<script charset="UTF-8">
alert('Ocorreu um erro de cadastro, tente novamente mais tarde.');
window.history.go(-1);
</script>
EOF;
exit($javascript);
}

//se não tiver perfil cadastrado ou tiver bloqueado
if (null === $perfis || empty($perfis)) {

$javascript = <<<EOF
<script charset="UTF-8">
alert('Não foi selecionado uma Operadora/Região. Caso a opção não esteja disponivel, tente novamente em outro momento.');
window.history.go(-1);
</script>
EOF;
exit($javascript);
}

//recupera o valor cobrado global
$dados_revenda = dados_revenda($id_revenda, 'valor_cobrado_global,id_modelo_padrao');

$login_teste['name'] = gera_login_rand($email);
$login_teste['displayname'] = $nome;
$login_teste['password'] = mt_rand(100, 999);
$login_teste['profiles'] = serialize($perfis);
$login_teste['email'] = strtolower(trim($email));
$login_teste['maxconnections'] = count($perfis);
$login_teste['enabled'] = 'true';
$login_teste['startdate'] = date("Y-m-d");
$login_teste['added'] = $login_teste['startdate'];
$login_teste['expiredate'] = date("Y-m-d H:i:s", strtotime("+{$config_salvo['tempo_login_teste']} hours"));
$login_teste['addedby'] = $id_revenda;
$login_teste['obs_user'] = 'Login criado automaticamente através do formulário.';
$login_teste['valor_cob'] = $dados_revenda['valor_cobrado_global'];

// cadastra novo login teste 
if (add_login_teste($login_teste)) {

// registra o teste pedido

$teste_pedido['email'] = strtolower(trim($email));
$teste_pedido['addedby'] = $id_revenda;
$teste_pedido['data_cad'] = date("Y-m-d");
$teste_pedido['ip'] = $_SERVER['REMOTE_ADDR'];
$teste_pedido['url_ref'] = $_SESSION['URL_REFERER'][0];

//registra teste 
registra_teste_pedido($teste_pedido);

// pega o modelo salvo na revenda
$modelo_email = modelo_email_revenda($id_revenda, $dados_revenda['id_modelo_padrao']);

//se não houve na revenda pegado sistema 
if (empty($modelo_email)) {

$modelo_email = modelo_email_sistema($config_salvo['id_modelo_padrao']);
}

//configurações do email para envio

/*
id int(11) Não
uid int(11) Não
email varchar(50) Não
nome_exibir varchar(25) Não
senha varchar(50) Não
serv_mail varchar(25) Não
data_cad datetime Não
data_atu datetime
*/

$config_email_revenda = email_envio_revenda($id_revenda);

if (empty($config_email_revenda) || empty($modelo_email)) {

$javascript = <<<EOF
<script charset="UTF-8">
alert('O login teste foi criado com sucesso, não foi enviado email pois os dados não estão configurados corretamente.');
window.history.go(-1);
</script>
EOF;
exit($javascript);
}

// variaveis do modelo de email.

$var_email['[EMVENDEDOR]'] = $config_email_revenda['email'];
$var_email['[NMVENDEDOR]'] = $config_email_revenda['nome_exibir'];
$var_email['[LGCLIENTE]'] = $login_teste['name'];
$var_email['[SNCLIENTE]'] = $login_teste['password'];
$var_email['[NMCLIENTE]'] = $login_teste['displayname'];
$var_email['[VCCLIENTE]'] = date("d/m/Y H:i:s", strtotime($login_teste['expiredate']));
$var_email['[DDSERVIDOR]'] = html_url_profiles(urls_profiles($id_revenda)); //'Dados servidor.(urls,portas)';
//substituindo variaveis de email no assunto e no corpo
$assunto = str_replace(array_keys($var_email), array_values($var_email), $modelo_email['assunto']);
$corpo = str_replace(array_keys($var_email), array_values($var_email), $modelo_email['corpo']);

//variaveis para envio do email
$dados_envio['para_email'] = $email;
$dados_envio['de_email'] = $config_email_revenda['email'];
$dados_envio['de_nome'] = $config_email_revenda['nome_exibir'];
$dados_envio['de_senha'] = dpt($config_email_revenda['senha'], $s);
$dados_envio['assunto_email'] = $assunto;
$dados_envio['corpo_email'] = $corpo;
$dados_envio['servidor_email'] = $config_email_revenda['serv_mail']; 
//var_dump($dados_envio);exit();

//processando o envio do email
smtpmailer3($dados_envio);

$javascript = <<<EOF
<script charset="UTF-8">
alert('Login criado com sucesso. Já foi enviado um email com os dados do login teste.');
window.location.replace('{$_SESSION['URL_REFERER'][0]}');
</script>
EOF;
exit($javascript);
}// if add_login
}// if $_POST
?>
<!-- topo -->
<?php require_once 'includes/topo.php'; ?>
<div class="container"> 
<div class="col-sm-6 col-sm-offset-3">
<h5><?= $titulo; ?></h5>
<div class="alert alert-warning">
Atualmente os testes estão configurados para <?= $config_salvo['tempo_login_teste']; ?> horas. 
</div>
<form method="post">
<div class="form-group">
<label>Seu nome:</label><input class="form-control" name="nome"/> 
</div>
<div class="form-group">
<label>Email:</label><input class="form-control" name="email"/> 
</div>
<div class="form-group">
<label>Operadora/Região Disponivel:</label>
<?php if (count($perfis_disp) > 0): ?>
<?php foreach ($perfis_disp as $perfil): ?>
<div><input name="perfil[]" type="<?= ($config_salvo['mult_perf'] == '0') ? 'radio' : 'checkbox' ?>" value="<?= $perfil['id'] ?>"/> <?= strtoupper($perfil['name']) ?></div>
<?php endforeach; ?>
<?php else: ?>
<div class="alert alert-danger">Não existem opções disponiveis no momento.</div>
<?php endif; ?>
</div>
<div class="form-group"><br /><br />


<button class="btn btn-primary" <?php if (empty($perfis_disp) || count($perfis_disp) == 0): ?>disabled="true"<?php endif; ?> >Solicitar</button>

</form>
<hr/>
<p class="text-center">Todos direitos reservados</p>
</div>
</div>
</body>
</html>

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
Sign in to follow this  

  • Similar Content

    • By Robson Barros da Rocha
      Olá! Estou com sérias dúvidas sobre as notificações push. Já instalado, ela segue este tutorial explicativo: https://www.phpzag.com/push-notification-system-with-php-mysql/ Esse método para mim é mais simples, mas, e já fiz as adaptações para comportar meu banco de dados, mas, o problema é que ele não me envia as notificações push quando estou fora do navegador ou via celuar por exemplo. Eu comentei no artigo mencionado, mas, o autor não me respondeu já tem uma semana.
      Alguém tem algum artigo que indique como posso realizar essas notificações push até mesmo quando o navegador estiver fechado e via aparelho celular?
    • By z101
      Sou iniciante, nunca usei PHP na vida e preciso concluir uma tabela de distribuição de frequencia e o polígono de um array, sendo isso apenas o começo do que preciso fazer, mas isso não vem ao caso agora. Depois de muito pesquisar, acabei com o seguinte código:
      <?php
              $category = 7;
              $data = array(
                  16, 17, 17, 18, 18, 18, 19, 20, 20, 20, 20, 20, 
                  21, 21, 22, 22, 23, 23, 23, 23, 23, 23, 23, 23, 
                  23, 25, 25, 25, 25, 25, 25, 26, 26, 27, 27, 27, 
                  27, 28, 28, 28, 29, 29, 29, 30, 30, 30, 30, 30, 
                  30, 30, 31, 32, 33, 33, 33, 34, 34, 35, 36, 39
              );
              $min = min($data);
              $max = max($data);
              $limit = ceil(($max - $min) / $category);
              sort($data);
              for ($i = 0; $i < $category; $i++) {
                  $count = 0;
                  foreach ($data as $key => $number) {
                      if ($number <=  (($min + ($limit - 1)) + ($i * $limit))) {
                          $count++;
                          unset($data[$key]);
                      }
                  }
                  echo ($min + ($i * $limit)) . '-' . (($min + ($limit - 1)) + ($i * $limit)) . ' => ' . $count.'<br>';
              }
       
      Ele compila, tudo bem, mas a saída tá errada: 
      16-19 => 7<br>20-23 => 18<br>24-27 => 12<br>28-31 => 14<br>32-35 => 7<br>36-39 => 2<br>40-43 => 0<br> Ele me retorna esses valores, mas devia ser: 
      16 - 19,3 -> 7
      19,3 - 22,6 ->  9
      22,6 - 25,9 -> 15
      25,9 - 29,2 -> 12
      29,2 - 32,5 -> 9
      32,5 - 35,8 -> 6
      35,8 - 39,1 -> 2
       
      O sete veio  daqui : k = 1 + 3,3log 60(60 pq sao 60  números) =  6,9,    esse numero tem que ser inteiro, daí o sete.
      Eu pensei que quando eu atribuisse 7 ao $category, ele ia fazer a divisão do menor valor - o maior valor por 7. No caso 16-39/7 = 3,3. Isso deveria gerar os valores certos, mas não aconteceu.
      Não sei como  arrumar, alguém pode  me ajudar?
       
       
    • By citypoa1
      boa tarde
       
      estou atualizando um script para usar em php 7, atualizei quase todas as funçoes mysql_ para mysqli, menos a mysqli_result que nao tem mais no php 7, pelo menos nao com a mesma funçao
      o codigo
       
       
      $boxes = 1; $tot24 = "0"; $out24 = "0"; $click24 = "0"; $intot = "0"; $outtot = "0"; $clicktot = "0"; $credittot = "0"; while($row = mysqli_fetch_object($result3)) { $result4 = mysqli_query($db1, "SELECT u0,u1,u2,u3,u4,u5,u6,u7,u8,u9,u10,u11,u12,u13,u14,u15,u16,u17,u18,u19,u20,u21,u22,u23 FROM stats WHERE id = $row->id"); $in = mysqli_fetch_array($result4, MYSQLI_NUM); $result5 = mysqli_query($db1, "SELECT o0,o1,o2,o3,o4,o5,o6,o7,o8,o9,o10,o11,o12,o13,o14,o15,o16,o17,o18,o19,o20,o21,o22,o23 FROM stats WHERE id = $row->id"); $out = mysqli_fetch_array($result5, MYSQLI_NUM); $result6 = mysqli_query($db1, "SELECT c0,c1,c2,c3,c4,c5,c6,c7,c8,c9,c10,c11,c12,c13,c14,c15,c16,c17,c18,c19,c20,c21,c22,c23 FROM stats WHERE id = $row->id"); $click = mysqli_fetch_array($result6, MYSQLI_NUM); $today = 0; $todayout = 0; $todayclick = 0; for($i=0;$i<=$thishour;$i++) { $today = $today + $in[$i]; } for($i=0;$i<=$thishour;$i++) { $todayout = $todayout + $out[$i]; } for($i=0;$i<=$thishour;$i++) { $todayclick = $todayclick + $click[$i]; } $totalins = $row->ins + $today; $totalout = $row->outs + $todayout; $totalclick = $row->clicks + $todayclick; if($row->ins24 == 0) $prod24 = "0%"; else $prod24 = round($row->click24 / $row->ins24 * 100) ."%"; if($totalins == 0) $prod = "0%"; else $prod = round($totalclick / $totalins * 100) ."%"; if($row->active == 0) { $bgimg = "../images/system/line2.jpg"; $enable = "<span onclick=\"enable('partner',$row->id);\" id=\"enable$row->id\"><img src=\"../images/system/enable.jpg\" id=\"enimg$row->id\"></span>"; } else { $bgimg = "../images/system/line.jpg"; $enable = "<span onclick=\"disable('partner',$row->id);\" id=\"enable$row->id\"><img src=\"../images/system/disable.jpg\" id=\"enimg$row->id\"></span>"; } if($row->chosen == 0) $chosenone = "No"; else $chosenone = "Yes"; if($row->noframe == 0) $nofrm = "Yes"; else $nofrm = "No"; $credits = round($totalins - $totalout * ($ratio / 100)); if($showdaily == 1) { $showin2 = $today; $showout2 = $todayout; if($today == 0) $showprod2 = "0%"; else $showprod2 = round($todayclick / $today * 100) ."%"; } else { $showin2 = $row->ins24; $showout2 = $row->out24; $showprod2 = $prod24; } if(strlen($row->domain) > 15) $domain = substr($row->domain, 0, 15)."..."; else $domain = $row->domain; $allplugs = mysqli_result(mysqli_query($db1, "SELECT COUNT(*) FROM content WHERE domain='$row->domain'"),0); $activeplugs = mysqli_result(mysqli_query($db1, "SELECT COUNT(*) FROM content WHERE domain='$row->domain' AND active=1"),0); o erro esta nas duas ultimas linhas, porque nao existe a funçao msqli_result, pesquisei todos os topicos aqui do forum e de outros forum sobre o meu problema, consegui resolver quase todos menos esse do mysqli_result
      ja tentei de todas as formas indicadas, a mais proxima foi 
      $allplugs = mysqli_query($db1, "SELECT COUNT(*) FROM content WHERE domain='$row->domain'"); $rows = $allplugs->fetch_assoc(); if(count($rows) > 0){ } $activeplugs = mysqli_query($db1, "SELECT COUNT(*) FROM content WHERE domain='$row->domain'"); $rows = $activeplugs->fetch_assoc(); if(count($rows) > 0){ } mas da o erro 
      Recoverable fatal error: Object of class mysqli_result could not be converted to string in /home2
      linha do erro:
      <div style=\"width:900px;float:left;\"><div class=\"edittitle\">Plugs(active):</div><div id=\"edittext\">$allplugs($activeplugs)</div></div>");
      echo "        <li id=\"li$row->id\">
       
      o problema ainda é a forma de usar a funçao mysqli_result, acho que fiz da forma errada
       
      alguem saberia onde esta o erro? ou indicar algum artigo relacionado...
    • By EvertonFD
      Bom dia estou fazendo u  ranking onde deve ser selecionado alguns critérios de desempate exemplo:
      Caso os pontos sejam iguais deve ser decidido pelos gols, só pra ressaltar estou aprendendo php então se tiver uma maneira melhor de fazer isso estou disposto a aprender, segue o codigo que estou usando:
       <?php
              $result_times = "  SELECT * FROM  times    WHERE grupos='4'  
                                                      
                                                      ORDER BY pontos    DESC";
              $resultado_times = mysqli_query( $conn, $result_times );
              while ( $row_times = mysqli_fetch_assoc( $resultado_times ) ) {
                  ?>
          
          <div class="row p-1 bg-light p-1 mt-1 ">
              <div class="col-md-3 ">
                  <img src="assets/images/times/<?php echo $row_times['id']; ?>/<?php echo $row_times['logo_time']; ?>" width="60">
                  <span>
                      <?php echo $row_times['nome']; ?>
                  </span>
              </div>
              <div class="col-md-1 col-4 align-self-center  border">
                  V- <?php echo $row_times['vitoria']; ?>
              </div>
              <div class="col-md-1 col-4 align-self-center border">E-<?php echo $row_times['empate']; ?></div>
              <div class="col-md-2 col-4 align-self-center border">D-<?php echo $row_times['derrota']; ?></div>
              <div class="col-md-2 col-4 align-self-center border">GF-<?php echo $row_times['gf']; ?></div>
              <div class="col-md-2 col-4 align-self-center border">GC-<?php echo $row_times['gc']; ?></div>
              <div class="col-md-1 col-4 align-self-center border">P-<?php echo $row_times['pontos']; ?></div>
          </div>
                  <!---->
                  <?php
              }
              ?>
            
          
    • By Matheus_Moura
      Boa tarde.
      Estou fazendo uma aplicação PHP em um PC Linux com Lubuntu como SO, para conexão com um banco de dados ORACLE 11g. Porém quando utilizo a função oci_connect ou qualquer outra função para oracle é retornado uma mensagem informando que estão indefenidas.
      Estou utilizando o XAMPP como servidor e fiz a configuração no caminho opt/lampp/etc/php.ini retirando o ; tanto no php_oci8.dll como também na php_oracle.dll, porém não obtive sucesso. Coloquei dentro da pasta opt também o instantclient já descompactado e utilizei o PECL para tentar ativar as OCI, porém mesmo assim ainda não consegui sucesso. Alguém teria alguma outra sugestão ?
       
      Att,
      Matheus Moura
×

Important Information

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