Ir para conteúdo

Arquivado

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

Recommended Posts

Warning: mysqli_query() expects parameter 2 to be string, object given in [/size]E:\xampp\htdocs\cadastro\cadastrar.php on line [/size]45

 

Warning: mysqli_query() expects parameter 2 to be string, object given in [/size]E:\xampp\htdocs\cadastro\cadastrar.php on line [/size]46

 

Alguém pode me ajudar??

cadastrar.php

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8" />
		<title>Cadastrar</title>
	</head>
	<body>
		<?php
		include 'config.php';
		
		$nome = isset( $_POST['nome'] ) ? $_POST['nome'] : 'valor_padrao';
		$sobrenome = isset( $_POST['sobrenome'] ) ? $_POST['sobrenome'] : 'valor_padrao';
		$email = isset( $_POST['email'] ) ? $_POST['email'] : 'valor_padrao';
		$usuarios = isset( $_POST['usuarios'] ) ? $_POST['usuarios'] : 'valor_padrao';
		$info = isset( $_POST['info'] ) ? $_POST['info'] : 'valor_padrao';
		
		// Vamos checar algum erro nos campos
		if ((!$nome) || (!$sobrenome) || (!$email) || (!$usuarios)){
			echo "ERRO: <br /><br />";
		
		if (!$nome){
			echo "Nome é requerido.<br />";
		}
		
		if (!$sobrenome){
			echo "Sobrenome é requerido.<br /> <br />";
		}
		
		if (!$email){
			echo "Email é um campo requerido.<br /><br />";
		}
		
		if (!$usuarios){
			echo "Nome de Usuário é requerido.<br /><br />";
		}
		
		echo "Preencha os campos abaixo: <br /><br />";
		
		include 'formulario_cadastro.php';
		}else{
			// Vamos checar se o nome do usuario escolhido ja existem no banco de dados
			$sql_email_check = mysqli_query($conexao,"SELECT COUNT(id) FROM usuarios WHERE email='{$email}'");
			$sql_usuarios_check = mysqli_query($conexao,"SELECT COUNT(id) FROM usuarios WHERE usuarios='{$usuarios}'");			
			
			$eReg = mysqli_query($conexao,$sql_email_check);// or exit(mysqli_error($conexao));					
			$uReg = mysqli_query($conexao,$sql_usuarios_check);// or exit(mysqli_error($conexao));
			
			$email_check = $eReg[0];
			$usuarios_check = $uReg[0];
			
			if (($email_check > 0) || ($usuarios_check > 0)){
				echo "<strong>ERRO</strong>: <br /><br />";
				if ($email_check > 0){
					echo "Este email já está sendo utilizado.<br /><br />";
					unset($email);
				}
				
			if ($usuarios_check > 0){
				echo "Este nome de usuário já está sendo utilizado.<br /><br />";
				unset($usuario);
			}
			
			include 'formulario_cadastro.php';
			}else{
				//Se passarmos por esta verificacção ilesos é hora de finalmente cadastrar os dados.
				
				//Vamos utilizar uma função para gerar a senha de forma randômica
				function gerarSenha($tamanho=9, $forca=0) {
					$vogais = 'aeiouy';
					$consoantes = 'bcdfghjklmnpqrstvwxz';
					if ($forca >= 1) {
						$consoantes.= 'BCDFGHJKLMNPQRSTVWXZ';
					}
					if ($forca >= 2) {
						$vogais .= "AEIOUY";
					}
					if ($forca >= 4) {
						$consoantes .= '123456789';
					}
					if ($forca >= 8 ) {
						$vogais .= '@#$%';
					}
					
					$senha = "";
					$alt = time() % 2;
					
					for ($i = 0; $i < $tamanho; $i++) {
						if ($alt == 1) {
							$senha .= $consoantes[(rand() % strlen($consoantes))];
							$alt = 0;
						} else {
							$senha .= $vogais[(rand() % strlen($vogais))];
							$alt = 1;
						}
					}
					
					return $senha;
				}
				
				$senha_randomica = gerarSenha();
				$senha = md5($senha_randomica);
				
				//Inserindo os dados no banco de dados
				$info = htmlspecialchars($info);
				$sql = mysqli_query($conexao,"INSERT INTO usuarios (nome,sobrenome,email,usuarios,senha,info,
				data_cadastro) VALUES ('$nome','$sobrenome','$email','$usuarios','$senha','$info',now())")
				or die( mysql_error());
				
				if (!$sql){
					echo "Ocorreu um erro ao criar sua conta, entre em contato.";
				}else{
					$id = mysqli_insert_id($conexao);
					
					//Enviar um email ao usuario para confirmação e ativar o cadastro!
					$headers = "MIME-Version: 1.0\n";
					$headers .= "Content-type: text/html; charset=iso-8859-1\n";
					$headers .= "From: Teu Domínio - Webmaster<email@teusite.com.br>";
					$subject = "Confirmação de cadastro - teusite.com.br";
					
					$mensagem = "Prezado {$nome} {$sobrenome},<br />
						Obrigado pelo seu cadastro em nosso site, <a href='http://www.teusite.com.br'>
						http://www.teusite.com.br</a>!<br /> <br />
						Para confirmar seu cadastro e ativar sua conta em nosso site, podendo acessar à
						áreas exclusivas, por favor clique no link abaixo ou copie e cole na barra de
						endereço do seu navegador.<br /> <br />
						<a href='http://www.teusite.com.br/ativar.php?id={$id}&code={$senha}'>'>http://www.teusite.com.br/ativar.php?id={$id}&code={$senha}'>
						http://www.teusite.com.br/ativar.php?id={$id}&code={$senha}
						</a>
						<br /> <br />
						Após a ativação de sua conta, você poderá ter acesso ao conteúdo exclusivo
						efetuado o login com os seguintes dados abaixo:<br > <br />
						<strong>Usuario</strong>: {$usuarios}<br />
						<strong>Senha</strong>: {$senha_randomica}<br /> <br />
						Obrigado!<br /> <br /><br />
						Esta é uma mensagem automática, por favor não responda!";
						mail($email, $subject, $mensagem, $headers);
						echo "Foi enviado para o email ".$email." um pedido de confirmação de cadastro,
						por favor verifique e sigas as instruções!";
				}
			}
		}
		?>
		<br /><br />Faça o seu login!<a href="formulario_login.html">Clique Aqui!</a>
	</body>
</html>

Compartilhar este post


Link para o post
Compartilhar em outros sites

Tente substituir este trecho

$sql_email_check = mysqli_query($conexao,"SELECT COUNT(id) FROM usuarios WHERE email='{$email}'");
			$sql_usuarios_check = mysqli_query($conexao,"SELECT COUNT(id) FROM usuarios WHERE usuarios='{$usuarios}'");			
			
			$eReg = mysqli_query($conexao,$sql_email_check);// or exit(mysqli_error($conexao));					
			$uReg = mysqli_query($conexao,$sql_usuarios_check);// or exit(mysqli_error($conexao));

Por este

$sql_email_check = "SELECT COUNT(id) FROM usuarios WHERE email='{$email}'";
			$sql_usuarios_check = "SELECT COUNT(id) FROM usuarios WHERE usuarios='{$usuarios}'";			
			
			$eReg = mysqli_query($conexao,$sql_email_check);// or exit(mysqli_error($conexao));					
			$uReg = mysqli_query($conexao,$sql_usuarios_check);// or exit(mysqli_error($conexao));

Compartilhar este post


Link para o post
Compartilhar em outros sites

Alterei e agora dá esse erro:

 

Fatal error: Cannot use object of type mysqli_result as array in E:\xampp\htdocs\cadastro\cadastrar.php on line 48

Compartilhar este post


Link para o post
Compartilhar em outros sites

config.php

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8" />
		<title>Conexão</title>
	</head>
	<body>
		<?php
		
		$host = "localhost";
		$user = "root";
		$senha = "";
		$banco = "cadastro";
		
		$conexao = mysqli_connect($host,$user,$senha,$banco);
		
		if (mysqli_connect_errno($conexao)) {
			echo "Erro: ".mysqli_connect_errno();
		}
		?>
	</body>
</html>

esse é o código que faz a conexão com o banco de dados.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Fiz essa alteração:

$sql_email_check = "SELECT COUNT(id) FROM usuarios WHERE email='{$email}'";
$sql_usuarios_check = "SELECT COUNT(id) FROM usuarios WHERE usuarios='{$usuarios}'";           
           
$eReg=mysqli_fetch_array($conexao,$sql_email_check);
$uReg=mysqli_fetch_array($conexao,$sql_usuarios_check);

E deu esse erro:

Warning: mysqli_fetch_array() expects parameter 1 to be mysqli_result, object given in E:\xampp\htdocs\cadastro\cadastrar.php on line 45

Warning:
mysqli_fetch_array() expects parameter 1 to be mysqli_result, object given in E:\xampp\htdocs\cadastro\cadastrar.php on line 46

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • 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.
    • Por landerbadi
      Olá pessoal, boa tarde
       
      Tenho uma tabela chamada "produtos" com os seguintes campos (id, produto) e outra tabela chamada "itens" com os seguintes campos (id, prod_01, prod_02, prod_03, prod_04).
       
      Na tabela produtos eu tenho cadastrado os seguintes produtos: laranja, maçã, uva, goiaba, arroz, feijão, macarrão, etc.
       
      Na tabela itens eu tenho cadastrado os itens da seguinte maneira:
       
      1, laranja, uva, arroz, feijão;
      2, maçã, macarrão, goiaba, uva;
      3, arroz, feijão, maçã, azeite
       
      Meu problema é o seguinte: 
      Eu escolho um produto da tabela "produtos", por exemplo "uva".  Preciso fazer uma consulta na tabela "itens" para ser listado todos os registros que contenham o produto "uva" e que todos os demais produtos estejam cadastrados na tabela "produtos".
       
      No exemplo acima seria listado apenas dois registros, pois o terceiro registro não contém o produto "uva". 
       
      Alguém pode me ajudar? Pois estou quebrando a cabeça a vários dias e não consigo achar uma solução.
    • 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, plural, ativo. Nela tem cadastrado vários itens e seu respectivo plural. No campo ativo eu coloco a letra "S" para informar que esta palavra está ativa no sistema. Por exemplo: 1, casa, casas, S 2, mesa, mesas, S 3, cama, camas, S 4, moto, motos, S 5, rádio, rádios O quinto registro "radio" não está ativo no sistema pois não tem um "S" no campo ativo. E outra tabela chamada "variações" com os seguintes campos (id, item1, item2, item3) com os seguintes registros: 1, casa, camas, moto 2, mesas, casas, radio 3, rádio, cama, mesa Eu preciso fazer uma busca na tabela variações da seguinte maneira: Eu escolho um registro na tabela "itens", por exemplo "casa". Preciso fazer com que o php me liste todos os registros da tabela "variações" que contenham a palavra "casa". Porém se tiver algum registro com a palavra "casas" também tem que ser listado. Neste caso ele irá encontrar dois registros. Agora eu preciso que o php verifique os demais itens e faça a listagem apenas dos item que estão ativos (que contenham um "S" no campo ativo. Neste caso ele irá encontrar apenas um registro, pois o segundo registro contém a palavra "rádio". E "rádio" não está ativo na tabela itens. Como faço isso?
    • Por First
      Olá a todos!
       
      Quando eu tento fazer o login me mostra esse erro "Could not log you in."; Alguém sabe me ajudar a resolver esse problema no meu código?
      <?php require_once("core/init.php"); if (Input::exists()) { if (Token::check(Input::get("token"))) { $validate = new Validate(); $validation = $validate->check($_POST, array( "username" => array("required" => true), "password" => array("required" => true) )); if ($validation->passed()) { $user = new User(); $remember = (Input::get("remember")) === "on" ? true : false; $login = $user->login(Input::get("username"), Input::get("password"), $remember); if ($login) { Session::flash("home", "Welcome back!"); Redirect::to("index.php"); } else { echo "Could not log you in."; } } else { foreach ($validation->errors() as $error) { echo $error."<BR>"; } } } } ?> <form action="" method="POST"> <div class="field"> <label for="username">Username</label> <input type="text" name="username" id="username"> </div> <div class="field"> <label for="password">Password</label> <input type="password" name="password" id="password"> </div> <div class="field"> <label for="remember"> <input type="checkbox" name="remember" id="remember"> Remember me </label> </div> <input type="hidden" name="token" value="<?php echo Token::generate(); ?>"> <input type="submit" value="Log in"> </form>  
       
      Desde já obrigado.
×

Informação importante

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