Jump to content
_danf

Cadastro PHP +SQL adicionar função

Recommended Posts

Senhores, boa noite!

Possuo um cadastro em php é SQL Server.

queria adicionar uma função, que ao selecionar um item do select fizesse um insert numa tabela especifica do DB

Exemplo:

   <select id="select-faction">
                <option value="opt">Escolha sua facção</option>
                <option value="1">Aliança da Luz (Light)</option>
                <option value="0">União da Fúria (Dark)</option>
            </select>

Database GameData > Table UserMaxGrow > 
Campos:
RowID, ServerID, UserUID, Conntry (0 Luz, 1 Furia), MaxGrow (3), Del (false)

Ao criar a conta, ele teria que inserir Por padrão:
 

Citar

 

RowID (Se já tive 15 contas, ele vai ser a 16 automatico eu acho( desculpem a falta de sabedoria.)

ServerID (1)

UserUID (Exemplo, a ultima conta e 34, no caso seria 35) não sei como se chama isso..

Country (0 ou 1 de acordo com a seleção)

MaxGrow (3)

Del (false)

 

 

Exemplo:

na imagem abaixo desde ja agradeço.

Screenshot_1.png

 

Cadastro.php

<?php
require_once('db.config.php');

$user_ip = $_SERVER['REMOTE_ADDR'];
$username = isset($_POST['username']) ? trim($_POST['username']) : '';
$password = isset($_POST['password']) ? trim($_POST['password']) : '';
$password2 = isset($_POST['password2']) ? trim($_POST['password2']) : '';
$email = isset($_POST['email']) ? trim($_POST['email']) : '';
$errors = array();
$success = false;

// Processar os dados POST.
if(isset($_POST) && !empty($_POST)){
	// VALIDAR LOGIN
	if(empty($username)){
		$errors[] = '<center><font color="#970808">E necessário um login*</font>';
	}else if(strlen($username) < 3 || strlen($username) > 16){
		$errors[] = '<center><font color="#970808">Seu login deve ter entre 3 e 16 caracteres.</font>';
	}else if(ctype_alnum($username) === false){
		$errors[] = '<center><font color="#970808">Seu login deve consistir de números e letras apenas.</font>';
	}else{
		  // VERIFICA SE O LOGIN JÁ EXISTE.
		$sql = "SELECT UserID FROM PS_UserData.dbo.Users_Master WHERE UserID = ?";
		$stmt = odbc_prepare($GLOBALS['dbConn'],$sql);
		$args = array($username);
		if(!odbc_execute($stmt,$args)){
			$errors[] = '<center><font color="#970808">Não foi possível determinar se esse usuário já existe no banco de dados.</font>';
		}elseif($row = odbc_fetch_array($stmt)){
			$errors[] = '<center><font color="#970808">Login já existente, utilize outro.</font>';
		}
	}
	
	//  VALIDAR SENHA
	if(empty($password)){
		$errors[] = '<center><font color="#A52A2A">Informe uma senha.</font>';
	}else if(strlen($password) < 3 || strlen($password) > 16){
		$errors[] = '<center><font color="#970808">A senha deve ter entre 3 e 16 caracteres.</font>';
	}else if($password != $password2){
		$errors[] = '<center><font color="#970808">As senhas não coincidem.</font>';
	}

	// E-MAIL COM VALIDAÇÃO "O USUÁRIO NÃO PODE CRIAR UMA CONTA COM O MESMO E-MAIL".
if(isset($_POST) && !empty($_POST)){

	if(empty($email)){
		$errors[] = '<center><font color="#970808">Informe um e-mail.</font>';
	}else if(strlen($email) < 5 || strlen($email) > 30){
		$errors[] = '<center><font color="#970808">O E-mail deve ter entre 5 e 30 caracteres de comprimento.</font>';
	}else{
       // VERIFICA SE O E-MAIL JÁ EXITE.
		$sql = "SELECT email FROM PS_UserData.dbo.Users_Master WHERE email = ?";
		$stmt = odbc_prepare($GLOBALS['dbConn'],$sql);
		$args = array($email);
		if(!odbc_execute($stmt,$args)){
			$errors[] = '<center><font color="#970808">Falha ao determinar se esse E-amil já existe no banco de dados.</font>';
		}elseif($row = odbc_fetch_array($stmt)){
			$errors[] = '<center><font color="#970808">O E-mail já foi usado. Escolha outro E-mail.</font>';
		}
	}
}

	// Persiste a nova conta no banco de dados se não ocorrerem erros anteriores.
	if(count($errors) == 0){
		$sql = "INSERT INTO PS_UserData.dbo.Users_Master
				(UserID,Pw,JoinDate,Admin,AdminLevel,UseQueue,Status,Leave,LeaveDate,UserType,Point,EnPassword,UserIp,email)
				VALUES (?,?,GETDATE(),0,0,0,0,0,GETDATE(),'N',0,'',?,?)";
		$stmt = odbc_prepare($GLOBALS['dbConn'],$sql);
		$args = array($username,$password,$user_ip,$email);
		if(odbc_execute($stmt,$args)){
			$success = htmlentities("{$username}, seu cadastro foi finalizado com sucesso!");
		}else{
			// Isso significa que a instrução inserir provavelmente não é válida para seu banco de dados. Corrija a consulta ou corrija seu banco de dados, sua escolha;)
			$errors[] = '<center><font color="#970808">Problema ao tentar criar sua conta, tente novamente.</font>';
		}
	}
}
// Determine which view to show.
if($success === false){
	require_once('cadastro.view.php');
}else{
	require_once('success.view.php');
}
?>

 

cadastro.view.php

<!DOCTYPE html>
<html lang="pt-br">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <link rel="stylesheet" href="login.css">
    <link rel="icon" href="https://img.icons8.com/officel/16/000000/code.png">
    <link href="https://fonts.googleapis.com/css2?family=Montserrat&display=swap" rel="stylesheet">
    <link href="https://fonts.googleapis.com/css2?family=Josefin+Sans&display=swap" rel="stylesheet">
    <title>Vamos lá? </title>
</head>
<body><br>
        <?php if(count($errors)){ ?>
			<ul id="error">
			<?php foreach($errors as $error){ ?>
				<li><?php echo $error; ?></li>
			<?php } ?>
			</ul>
		<?php } ?>
         <div class="form-register">
            <form action="cadastro.php" method="POST">
            <h1>Criar uma nova conta</h1>
            <br><br>
            <input value="<?php if(isset($_POST['username'])){ echo $_POST['username']; } ?>" type="text" title="Login" placeholder="Login*" name="username">
            <br><br><br>
            <input value="<?php if(isset($_POST['password'])){ echo $_POST['password']; } ?>" type="password" title="Senha" placeholder="Senha" name="password">
            <br><br><br>
            <input value="<?php if(isset($_POST['password2'])){ echo $_POST['password2']; } ?>" type="password" title="Confirmar senha" placeholder="Confirmar senha" name="password2">
            <br><br><br>
            <input value="<?php if(isset($_POST['email'])){ echo $_POST['email']; } ?>" type="mail" title="E-mail" placeholder="Endereço de e-mail" name="email">
            <label>Utilize um e-mail válido para confirmação</label>
            <br><br>
            <select id="select-faction">
                <option value="opt">Escolha sua facção</option>
                <option value="0">Aliança da Luz (Light)</option>
                <option value="1">União da Fúria (Dark)</option>
            </select>
            <br><br>
            <button type="submit">Cadastrar</button>
            <br><br>
            <h2><a href="index.html"> Já possui um acesso?</a></h2>
            </form>
         </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

  • Similar Content

    • By Wallcrawler
      Olá pessoal tudo bem? Estou tentando fazer a cópia de uma imagem que está disponível na web e salvar em uma pasta no meu projeto. Essa imagem está sob protocolo SSL mas navegador consegue acessá-la normalmente. Mas o meu script php é bloqueado, e não entendo o porquê.
       
      Segue o código que estou usando:
      <?php //error_reporting(E_ALL ^ E_DEPRECATED); //ini_set('display_errors', 1); //die('Script travado!'); $start = microtime(true); set_time_limit(0); function save_image($inPath,$outPath) { //Download images from remote server $in = fopen($inPath, 'rb'); $out = fopen($outPath, 'wb'); while ($chunk = fread($in,8192)) { fwrite($out, $chunk, 8192); } fclose($in); fclose($out); } include_once ($_SERVER['DOCUMENT_ROOT'] . '/grpi/include/classes/Rpi.class.php'); include_once ($_SERVER['DOCUMENT_ROOT'] . '/grpi/include/functions.class.php'); $func = new FuncoesAuxiliares(); $rpi = new Rpi(); if(!isset($_GET['num_processo'])) { $rows = $rpi->Consulta('select num_processo, classe, especificacao from processos order by num_processo ASC limit 1'); } else { $rows = $rpi->Consulta("select num_processo, classe, especificacao from processos where num_processo > '" . $_GET['num_processo'] . "' order by num_processo ASC limit 1"); } $registros = 0; $arrayInsert = array(); $qtd_caracteres_total = 14; foreach ($rows as $rs) { //$rs['num_processo'] $zeros = ''; $qtd_char_processo = strlen($rs['num_processo']); //Fill zeros for($i=0; $i < ($qtd_caracteres_total - $qtd_char_processo); $i++) { $zeros .= '0'; } echo('BR5' . $zeros . $rs['num_processo'] . '<br>'); $url = 'http://www.tmdn.org/tmview/trademark/image/BR5' . $zeros . $rs['num_processo']; //Aqui tento acessar a imagem e salvar na pasta correspondente save_image($url, __DIR__ .'/logo/' . $rs['num_processo'] . '.jpg'); //copy('https://www.tmdn.org/tmview/trademark/image/BR5' . $zeros . $rs['num_processo'], __DIR__ .'/logo/' . $rs['num_processo'] . '.jpg'); $processo = $rs['num_processo']; $registros++; } $registros = number_format($registros, 0, ',', '.'); // Display Script End time $time_end = microtime(true); //dividing with 60 will give the execution time in minutes other wise seconds $execution_time = ($time_end - $start)/60; //execution time of the script echo '<b>Total Execution Time:</b> '. $execution_time .' Mins <hr><br><br>Registros: ' . $registros . '<br><br>'; echo("<a href='down_logo.php?num_processo=" . $processo ."' target='_self'>Próxima página</a><br><br>"); ?> O erro retornado é o seguinte:
       
      Warning: fopen(): SSL: Connection reset by peer in /home/storage/8/23/2c/euregistrogrpi/public_html/grpiv2/rpi/down_logo.php on line 10

      Warning: fopen(http://www.tmdn.org/tmview/trademark/image/BR500000825642590): failed to open stream: HTTP request failed! in /home/storage/8/23/2c/euregistrogrpi/public_html/grpiv2/rpi/down_logo.php on line 10

      Warning: fread() expects parameter 1 to be resource, boolean given in /home/storage/8/23/2c/euregistrogrpi/public_html/grpiv2/rpi/down_logo.php on line 12

      Warning: fclose() expects parameter 1 to be resource, boolean given in /home/storage/8/23/2c/euregistrogrpi/public_html/grpiv2/rpi/down_logo.php on line 16
       
      Só que se você tentar acessar o endereço no browser, diretamente, a imagem aparece:
       
      https://www.tmdn.org/tmview/trademark/image/BR500000825642590 
       
      Onde posso estar errando? Obrigado pela atenção de todos.
    • By violin101
      Caros amigos,
       
      saudações...
       
      Estou escrevendo uma rotina de Carrinho de Compras e estou com problema na Library CART.
       
      Quando a Descrição do Produto ultrapassa 25 caracteres, o CART não é inserido.
       
      A library CART, estou chamando direto no AUTOLOAD.
       
      Como consigo resolver esse problema ?
       
      O Código para inserir está assim:
      <?php defined('BASEPATH') OR exit('No direct script access allowed'); class Carrinho extends CI_Controller { public function __construct() { parent::__construct(); $this->load->model('site/carrinho_model'); } public function index() { $this->addCart(); } public function addCart() { //Recebe dados via POST $id_produto = $this->input->post("idPrds"); $descricao = $this->input->post("namPrds"); //Problema nesse Campo quando ultrapassa 25 caracteres - Não INSERE $quantidade = $this->input->post("qtds"); $preco = $this->input->post("vlrPrds"); $insert_dados = array( 'id' => $id_produto, 'name' => $descricao, 'price' => $preco, 'qty' => $quantidade ); $this->cart->insert($insert_dados); $this->load->view('site/estilo/header', $this->data); $this->load->view('site/carrinho'); } }  
       
      Grato,
       
      Cesar
       
       
       
       
    • By Bruno Ferreira da Silva
      Estou utilizando laravel 5.8.
      Meu problema é o seguinte, estou realizando o login com usuário e senha. O sistema entra na condição e debuga corretamente o usuário logado. e no mesmo momento que eu altero a url para ..../dashboard, ele redireciona como se estivesse deslogando. mas na segunda tentativa isso não acontece, ele realiza o login normalmente. Ai isso se repete sempre que troca de usuário. 
       
      O controller da dashboard chama apenas a view e mais nada. 
      public function authenticate(Request $request) { $credentials = $request->only('email', 'password'); if (Auth::attempt($credentials)) { dd(Auth::user()); return redirect()->intended('dashboard'); } }  
    • By Sapinn
      Estou trazendo os dados do banco de dados e eles estão vindo com problema na acentuação
      uso o seguinte codigo no php
      <?php
      include_once ‘…/php/conexao.php’;
      header(‘Content-Type: text/html; charset=utf-8’);
      mysqli_query($conn,“SET NAMES ‘utf8’”);
      mysqli_query($conn,‘SET character_set_connection=utf8’);
      mysqli_query($conn,‘SET character_set_client=utf8’);
      mysqli_query($conn,‘SET character_set_results=utf8’);
      ?>
      E no html
      Mesmo assim as palavras com acento ficam com aquele erro desgraçado com a interrogação
      Alguem me ajuda ai
    • By Wanderson Moreira
      Boa tarde
      Alguém poderia me ajudar com uma situação?
       
      Estou tentado comparar datas para me retornar 3 situações: Vencendo, Vencido, e Ativo
      porem acredito que o formato delas estejam erradas, pois ao compará-las o valor retorna errado
       
      $data = date_create("30-07-2020"); $vencimento = date_format($data, "d-m-Y"); $dataHoje = date("d-m-Y"); $dataVencer = date('d-m-Y', strtotime('+15 days')); if($vencimento > $dataVencer){echo 'Ativo';}  
      no exemplo estou comparando se 30-07-2020 for maior > 07-08-2020 exibir o texto "Ativo"
      Porem 30-07-2020 não é maior do que 07-08-2020 e mesmo assim o valor retornado esta sendo "ativo"
       
       
       

       
       
×

Important Information

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