Skellton 1 Denunciar post Postado Outubro 22, 2014 então galera eu do editando e terminando uma website para meu servidor de pb porem esta dando erro não sei oque eu fis quando eu coloco os dados para criar a conta ele , da uma falha na conexão com db do postgre Vou deixar uns Prints e so codico do registro php Criação da conta : Codico de php do register : Config.properties : app42.paas.db.username = postgres app42.paas.db.port = 5432 app42.paas.db.password = guilherme1 app42.paas.db.ip = 127.0.0.1 app42.paas.db.name = postgres DBManager.php : <?php class DBManager { public $client; public $selected; public function __construct() { $lines = file("Config.properties"); foreach ($lines as $line) { list($k, $v) = explode('=', $line); if (rtrim(ltrim($k)) == rtrim(ltrim("app42.paas.db.username"))) { $user = rtrim(ltrim($v)); }if (rtrim(ltrim($k)) == rtrim(ltrim("app42.paas.db.port"))) { $port = rtrim(ltrim($v)); }if (rtrim(ltrim($k)) == rtrim(ltrim("app42.paas.db.password"))) { $password = rtrim(ltrim($v)); }if (rtrim(ltrim($k)) == rtrim(ltrim("app42.paas.db.ip"))) { $ip = rtrim(ltrim($v)); }if (rtrim(ltrim($k)) == rtrim(ltrim("app42.paas.db.name"))) { $dbName = rtrim(ltrim($v)); } } $this->client = pg_connect("host=$ip port=$port dbname=$dbName user=$user password=$password") or die('Could not connect: ' . pg_last_error()); } function saveDoc($username, $email, $password) { /* try{ pg_query("CREATE TABLE accounts(login VARCHAR(255), email VARCHAR(355), password VARCHAR(355), money VARCHAR(355))"); }catch(Exception $e){ print_r("Table Already Created"); } */ $query = "insert into accounts(login,email,password,money) values('$username','$email','$password','100000')"; $result = pg_query($query) or die ("<meta http-equiv='refresh' content='=0;URL=?s=notfound' />"); pg_close($this->client); } function getAllDocs() { $query = "select * from accounts"; $result = pg_query($query) or die('Query failed: ' . pg_last_error()); return $result; } function getPlayer() { $query = "select * from players"; $result = pg_query($query) or die('Query failed: ' . pg_last_error()); return $result; } } ?> register.php: <div class="App42PaaS_body_wrapper"> <div class="App42PaaS_body"> <div class="App42PaaS_body_inner"> <div class="contactPage_title">Registro</div> <div class="form_wrapper"> <form method="post" action="save.php"> <fieldset> <legend>Criar Conta</legend> <div class="contactForm_tr"> <div class="contactForm_td1">Nome</div> <div class="contactForm_tdMiddle">: </div> <div class="contactForm_td2"> <input name="username" type="text" class="Personal-input" id="contactPerson" value=""></div> <div class="contactForm_td2" style="color: red; padding-left: 90px; display: none;" id="contactPersonErr">Please Input Field Name</div> </div> <div class="contactForm_tr"> <div class="contactForm_td1">Email</div> <div class="contactForm_tdMiddle">: </div> <div class="contactForm_td2"><input name="email" type="text" id="email" class="Personal-input" maxlength="30"> </div> <div class="contactForm_td2" style="color: red; padding-left: 90px; display: none;" id="emailErr">Please Input Field Email</div> </div> <div class="contactForm_tr"> <div class="contactForm_td1">senha</div> <div class="contactForm_tdMiddle">: </div> <div class="contactForm_td2"><input name="password" type="password" id="password" class="Personal-input" maxlength="30"> </div> <div class="contactForm_td2" style="color: red; padding-left: 90px; display: none;" id="passErr">Please Input Field Password</div> </div> </fieldset> <center> <div class="form-button" style="margin-left:100px; margin-right:10px;"><input id="SubmitButton" class="submit_btn" type="image" border="0" name="submit" alt="Register" src="images/submit_btn.png"></input></div> <!-- <div class="form-button"><input id="Submit" class="clear_btn" type="image" border="0" name="clear" alt="clear" src="images/clear_btn.png"></div> --> </center> </form> </div> save.php: <?php error_reporting(0); $username = $_POST["username"]; $email = $_POST["email"]; $password = md5($_POST['password']); require_once "DBManager.php"; $client = new DBManager(); $client->saveDoc($username, $email, $password); header("Location: ?s=Success"); ?> Success.php: <!doctype html> <html> <head> <meta charset="utf-8"> <title>Project Wars</title> <style> body { background : url(images/Success.png) no-repeat #000000 50% -50%;} } </style> </head> <body> <meta http-equiv="refresh" content="2;url=?s=home" /> </body> </html> Compartilhar este post Link para o post Compartilhar em outros sites
rockrgo 138 Denunciar post Postado Outubro 22, 2014 cara vc colocou tudo, menos o erro! Qual erro que está dando? Compartilhar este post Link para o post Compartilhar em outros sites
Skellton 1 Denunciar post Postado Outubro 22, 2014 @ rockrgo Quando clico em submit para criar conta, os dados não vai para db Compartilhar este post Link para o post Compartilhar em outros sites
rockrgo 138 Denunciar post Postado Outubro 22, 2014 ta mas não aparece nenhum erro? Compartilhar este post Link para o post Compartilhar em outros sites
Skellton 1 Denunciar post Postado Outubro 22, 2014 @ rockrgo não , ele vai para pagina save.php e fica tudo branco , era para ir para pagina Success.php se vocé puder manda seu contato para me ajudar agradeço! Compartilhar este post Link para o post Compartilhar em outros sites
rockrgo 138 Denunciar post Postado Outubro 22, 2014 comenta esta parte no seu código e vê se aparece algum erro. error_reporting(0); Compartilhar este post Link para o post Compartilhar em outros sites
Skellton 1 Denunciar post Postado Outubro 22, 2014 @rockrgo eu coloquei o error_reporting(0); não apareçe erro. se vocé quiser posso mandar website e a db , db é leve Compartilhar este post Link para o post Compartilhar em outros sites
rockrgo 138 Denunciar post Postado Outubro 23, 2014 @rockrgo eu coloquei o error_reporting(0); não apareçe erro. se vocé quiser posso mandar website e a db , db é leve Não é para colocar e sim para tirar o erro_reporting(0) ou substitua por error_reporting(E_ALL);. Pois com o error_reporting setado como 0 você está ocultando as mensagens Compartilhar este post Link para o post Compartilhar em outros sites
Skellton 1 Denunciar post Postado Outubro 23, 2014 @rockrgo Pronto deu esse erro. Oque eu edito aqui ??? Compartilhar este post Link para o post Compartilhar em outros sites
Fernando C 128 Denunciar post Postado Outubro 23, 2014 olha.. verifique se está corretamente instalada a extensão ao Postgres; para isso vc pode usar 1 pg só p/ conexão, acho + simples por exemplo essa DBManager.php, mesmo. outra forma é ver a pasta de extensões.. Compartilhar este post Link para o post Compartilhar em outros sites
rockrgo 138 Denunciar post Postado Outubro 23, 2014 Conforme o Fernando C disse, precisa ter instalada a extensão. Você está utilizando qual servidor? Se for um Wamp é só abrir o menu do wamp > PHP > PHP extensions e clicar em php_pgsql e depois você restarta os serviços. Compartilhar este post Link para o post Compartilhar em outros sites
Skellton 1 Denunciar post Postado Outubro 24, 2014 @rockrgo to usando Apache2.2 Compartilhar este post Link para o post Compartilhar em outros sites
rockrgo 138 Denunciar post Postado Outubro 24, 2014 você instalou o php e o apache separadamente? Qual sistema operacional está usando? Compartilhar este post Link para o post Compartilhar em outros sites
Skellton 1 Denunciar post Postado Outubro 24, 2014 @rockrgo Compartilhar este post Link para o post Compartilhar em outros sites
rockrgo 138 Denunciar post Postado Outubro 24, 2014 Cara acho que você não tem o PostgreSql instalado no seu servidor, porquê não usa o MySql? Compartilhar este post Link para o post Compartilhar em outros sites
Skellton 1 Denunciar post Postado Outubro 24, 2014 @rockrgo tenho sim, my sql era para antes, agora que db mudo foi para postgre Compartilhar este post Link para o post Compartilhar em outros sites
Beraldo 864 Denunciar post Postado Outubro 25, 2014 Você pode ter o PostgreSQL instalado, mas precisa ter certeza de que possui a extensão pgsql habilitada/ Crie um arquivo só pra testar a conexão: // crie as variaveis com os dados de conexao aqui pg_connect("host=$ip port=$port dbname=$dbName user=$user password=$password") or exit( pg_last_error() ); PS: sugiro que use PDO, que é uma camada do PHP para abstrair bancos de dados. É mais recente e, caso mude de SGBD no futuro, o PDO dará conta disso, sem precisar mexer no código. Compartilhar este post Link para o post Compartilhar em outros sites
Skellton 1 Denunciar post Postado Outubro 25, 2014 @beraldo http://www.winderhost.com.br:8080/teste.php Compartilhar este post Link para o post Compartilhar em outros sites
Beraldo 864 Denunciar post Postado Outubro 25, 2014 Isso quer dizer que a extensão pgsql não está ativa. Você precisa ativá-la no php.ini, como já foi citado anteriormente. Compartilhar este post Link para o post Compartilhar em outros sites
Skellton 1 Denunciar post Postado Outubro 26, 2014 @Beraldo aqui no forum tem algun tutorial sobre a extensão ? como ativar e instalar Compartilhar este post Link para o post Compartilhar em outros sites