Jump to content
heenrique

Limitar quantidade de acesso como o mesmo código (login)

Recommended Posts

Bom Dia Prezados!

 

estou realizando o desenvolvimento de um sistema multi empresas no ao acessar ira pedir um código, ate a parte do código tudo OK, apos passar esse código vai para um tela de login onde cada meu sistema é ligado com o banco de dados do sistema (é um sistema padrão)do cliente ate aqui OK. gostaria de limitar a quantidade de acesso a esse código, ex empresa 1 contratou código com 3 acessos, empresa 2 contratou 1 acesso, alguém tem um dica ou um outro método para realizar esse controle ?

Share this post


Link to post
Share on other sites

É muito complexo fazer isso sem saber como funciona o teu sistema, mas eu fiz uma base pra você.

Obviamente tá cheio de falhas, mas você pode corrigir.

 

Resumo: a empresa petrobras tem 5 códigos cadastrados. Ao logar com um código, ele apaga o código e reduz a quantidade de códigos da empresa.

 

BD.sql

CREATE TABLE `empresas` (
	`id` INT NOT NULL AUTO_INCREMENT,
	`empresa` VARCHAR(30) NOT NULL,
	`codigos` CHAR(3) NOT NULL,

	PRIMARY KEY (`id`));

INSERT INTO `empresas` (`id`,`empresa`, `codigos`) VALUES (1, 'Petrobras', '5');

CREATE TABLE `codigos` (
	`id` INT NOT NULL AUTO_INCREMENT,
	`empresa` VARCHAR(30) NOT NULL,
	`codigo` VARCHAR(50) NOT NULL,

	PRIMARY KEY (`id`));

INSERT INTO `codigos` (`id`,`empresa`, `codigo`) VALUES (1, 'Petrobras', 'hwaniaw');
INSERT INTO `codigos` (`id`,`empresa`, `codigo`) VALUES (2, 'Liquigas', 'eareafe');
INSERT INTO `codigos` (`id`,`empresa`, `codigo`) VALUES (3, 'Petrobras', 'eare4546afe');
INSERT INTO `codigos` (`id`,`empresa`, `codigo`) VALUES (4, 'Petrobras', 'e1324are23244546afe');
INSERT INTO `codigos` (`id`,`empresa`, `codigo`) VALUES (5, 'Petrobras', 'eare13234546afe');
INSERT INTO `codigos` (`id`,`empresa`, `codigo`) VALUES (6, 'Petrobras', 'zdsacda43');

conexao.php

<?php

$Servidor = 'localhost';
$nomeBanco = 'ale';
$Usuario = 'root';
$Senha = '';
$strcon = mysqli_connect($Servidor, $Usuario, $Senha, $nomeBanco); 

?>

conexao2.php

<?php

$conexao = mysqli_connect('localhost','root','') or die (header('Location: manutencao/'));
$banco = mysqli_select_db($conexao,'ale') or die (header('Location: manutencao/'));

?>

index.php


<form method="POST" action="vai.php">
	<input type="text" name="corporation" placeholder="digite aqui o nome da empresa" />
	<input type="text" name="token" placeholder="digite aqui ó código" />
	<input type="submit" value="logar" />
</form>


<h4>Empresas: </h4>
<?php

include ('conexao.php');
include ('conexao2.php');


$sql = mysqli_query($conexao,"SELECT * FROM empresas") or die ('a conexão falhou');
while($empresas=mysqli_fetch_assoc($sql))
{
	echo '<p>A empresa <b>';
	echo $empresas['empresa'];
	echo '</b> possui ';
	echo $empresas['codigos'];
	echo ' códigos disponíveis';
}

?>

vai.php

<?php

include ('conexao.php');
include ('conexao2.php');

$fcorp = addslashes($_POST['corporation']);
$ftoken = addslashes($_POST['token']);

if (ctype_alpha($fcorp)) {
	if (ctype_alnum($ftoken)) {
		//
		$sql = mysqli_query($conexao,"SELECT * FROM empresas WHERE empresa = '{$fcorp}' LIMIT 1") or die ('a conexão falhou');
		while($ecodigo=mysqli_fetch_assoc($sql))
		{
			$qtdempresa = $ecodigo['codigos'];
			$qtdempresa1 = $ecodigo['codigos'];
			$qmerda = $qtdempresa - 1;
		}

		if ($qtdempresa1 < 1) {
			echo 'a sua empresa nao tem codigos';
			exit;
		}

		if ($qtdempresa1 >= 1) {
			
			$sql = mysqli_query($conexao,"SELECT * FROM codigos WHERE codigo = '{$ftoken}' LIMIT 1") or die ('a conexão falhou');
			while($etoken=mysqli_fetch_assoc($sql))
			{
				$tokendigitado = $etoken['codigo'];
			}
			
			if (!$strcon) {
				die('Não foi possível conectar ao Banco de Dados');
			}
			$sql = "DELETE FROM codigos WHERE codigo = '{$ftoken}'";
			mysqli_query($strcon,$sql) or die("Erro ao tentar alterar.");
			
			if (!$strcon) {
				die('Não foi possível conectar ao Banco de Dados');
			}
			$sql = "UPDATE empresas SET codigos='{$qmerda}' WHERE empresa = '{$fcorp}'";
			mysqli_query($strcon,$sql) or die("Erro ao tentar alterar.");
			
			echo 'tudo certo';
			exit;
		}else{
			echo 'a sua empresa não tem mais códigos';
			exit;
		}
	}else{
		echo 'o código não é alfanumérico';
		exit;
		} 			# FIM IF CTYPE ALNUM TOKEN
	}else{
		echo 'o nome da empresa não pode ter números';
		exit;
	} 		# fim IF ctype alpha corp
	?>

 

Share this post


Link to post
Share on other sites

Olá Megao, obrigado pela resposta, entao um metodo mais facil para executar isso seria por ex.

Cliente - 3 Acessos

  Codigo 1 = 1234-4321

 Codigo 2 = 1111-1111

Codigo 3 = 2222-2222

 

e impedir que um codigo faça mais de um login por vez

 

CREATE TABLE `empresas` (
	`id` INT NOT NULL AUTO_INCREMENT,
	`empresa` VARCHAR(30) NOT NULL,

	PRIMARY KEY (`id`));

INSERT INTO `empresas` (`id`,`empresa`) VALUES (1, 'CLIENTE 1');
INSERT INTO `empresas` (`id`,`empresa`) VALUES (2, 'CLIENTE 2');

//-------------------------------------------------------------------------------------
CREATE TABLE `codigos` (
	`id` INT NOT NULL AUTO_INCREMENT,
	`id_emp` VARCHAR(30) NOT NULL,
	`codigo` VARCHAR(50) NOT NULL,
	`ativo` INT NOT NULL,

	PRIMARY KEY (`id`));

INSERT INTO `codigos` (`id`,`id_emp`, `codigo`, `ativo`) VALUES (1, '1', '1111-1111', '0');
INSERT INTO `codigos` (`id`,`id_emp`, `codigo`, `ativo`) VALUES (2, '1', '2222-2222', '0');
INSERT INTO `codigos` (`id`,`id_emp`, `codigo`, `ativo`) VALUES (3, '1', '3333-3333', '0');
INSERT INTO `codigos` (`id`,`id_emp`, `codigo`, `ativo`) VALUES (4, '2', '4444-4444', '0');
INSERT INTO `codigos` (`id`,`id_emp`, `codigo`, `ativo`) VALUES (5, '2', '5555-5555', '0');
INSERT INTO `codigos` (`id`,`id_emp`, `codigo`, `ativo`) VALUES (6, '2', '6666-6666', '0');
//0 para nao ativo e 1 para ativo

No caso poderia criar um local onde ele vai verificar quantidade de código e possa identificar o código por ex codigo 1111-1111 fulano de tal

 

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 msantino
      Bom dia.
       
      Estou desenvolvendo uma aplicação que vai acessar e gravar dados via webservice dentro do nosso crm... mas estou com um problema que quando tento fazer o acesso mostra a seguinte mensagem de erro:
       
      Fatal error: Uncaught SoapFault exception: [WSDL] SOAP-ERROR: Parsing Schema: can't import schema from 'http://dsksp015.phonoway.com.br:8051/wsDataServer/mex?xsd=xsd0' in /home/httpd/html/phonoweb.com.br/public_html/carrinhobitrix_busca/teste_soap.php:113 Stack trace: #0 /home/httpd/html/phonoweb.com.br/public_html/carrinhobitrix_busca/teste_soap.php(113): SoapClient->SoapClient('http://187.93.2...') #1 {main} thrown in /home/httpd/html/phonoweb.com.br/public_html/carrinhobitrix_busca/teste_soap.php on line 113
       
      Não sei se faz alguma diferença, mas nosso CRM é o TOTVS RM
       
      Grato.
    • By mamotinho
      Boa noite! estou com dúvidas em relação a array, eu tenho uma procedure no SQL Server e essa procedure exibe uma lista de resultados, eu gostaria de pega o valor desses resultados e lista em um array para eu comparar com outro valor que vai ser selecionado em um select , tipo abaixo:
       
      $arraySelect = $db->prepare(exec WebSite.dbo.server_value_product 2);
      $arraySelect->execute();
      $arrayExemple = $arraySelect->fetchAll();

      procedure_list = array($arrayExemple);
       
      !in_array($valorSelect, $procedure_list){
         echo 'O Valor selecionado não existe nos resultados da procedure';
      }
       
       
      alguem sabe como posso listar o resultado da procedure em array. e sabe se o valor que procuro está entre os resultados da array.
    • By asacap1000
      Galera já não sei mais onde procurar, estou configurando o processo de login com certificação digital porém não consigo ler o retorno. No site da Certisign explica em java e .Net mas utilizo em minha aplicação da intranet tudo em PHP como eu teria que fazer. Segue exemplo que eles fornecem em .Net
       
      <form action="https://autenticador.certisign.com.br/CertisignLogin/certificado/login" method="get"> <input type="hidden" value="209" id="id" name="id"> <input type="hidden" value="CHAVE CRIPTOGRAFICA INICIAL" id="nome" name="nome"> <input type="hidden" value="http://www.seusite.com.br/suaAplicacao/retorno" id="retorno" name="retorno"> <div> <input type="image" src="images/ico-certisign_30x30.png" alt="Submit" id="btnLoginCertisign"> </div> </form> O de cima envia até aí tudo bem
       
      Abaixo o retorno que é o que não consigo fazer em PHP
       
      string retorno = Request["cb"]; string encryptionKey = "<conteúdo da chave criptográfica descarregada na etapa 2>"; retorno = CryptoLogin.Instance.DecryptText(retorno,encryptionKey);</conteúdo> A variável retorno deverá mostrar as informações como o exemplo aaixo.
       
      CertificadoBean: { emissor: Certisign Autoridade Certificadora TESTE, nome: "PROPRIETARIO DO CERTIFICADO DE TESTE", cpf: "001.002.003-44", cnpj: "", OAB: "", validade: "2015-05-27 20:59:59", emissao: "2014-05-27 21:00:00", email: "proprietario.teste@certisign.com.br", certificadoBase64: "MIIFmDCCBICgAwI...... BAQUFADCCARAx" }  
    • By Camilavip
      Queria saber como fazer esse select e quando eu trazer um estado ele já puxa as cidades contidos nele, e ao escolher a cidade ele trazer os bairros. Consegui pela internet mas só com estados e cidades. no caso em 2 níveis, e eu precisaria em 3, faço pelo mysqli
       
      Em estados no banco está assim
      CREATE TABLE `estados` ( `id_estado` int(10) NOT NULL, `estado` varchar(30) NOT NULL ) ENGINE=Aria DEFAULT CHARSET=latin1; -- -- Extraindo dados da tabela `estados` -- INSERT INTO `estados` (`id_estado`, `estado`) VALUES (1, 'Rio de Janeiro'), (2, 'Minas Gerais'); Cidades
      CREATE TABLE `cidades` ( `id_cidade` int(10) NOT NULL, `id_estado` int(10) NOT NULL, `cidade` varchar(255) NOT NULL ) ENGINE=InnoDB DEFAULT CHARSET=latin1; -- -- Extraindo dados da tabela `cidades` -- INSERT INTO `cidades` (`id_cidade`, `id_estado`, `cidade`) VALUES (1, 1, 'Rio de Janeiro'), (2, 2, 'Belo Horizonte'); E bairros
      CREATE TABLE `bairros` ( `id_bairro` int(10) NOT NULL, `id_cidade` int(10) NOT NULL, `bairro` varchar(255) NOT NULL ) ENGINE=InnoDB DEFAULT CHARSET=latin1; -- -- Extraindo dados da tabela `bairros` -- INSERT INTO `bairros` (`id_bairro`, `id_cidade`, `bairro`) VALUES (1, 1, 'Centro'), (2, 1, 'Tijuca'), (3, 1, 'Leblon'), (4, 2, 'Pampulha');  
×

Important Information

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