Jump to content
Andressa Maria

PHP conectar com Oracle em outro servidor

Recommended Posts

Preciso realizar a conexão de uma pagina PHP com banco do Oracle, porem este banco esta em um servidor diferente!

Já passei a string do tnsnames na variável de conexão, porem quando abro a pagina não mostra nada!

<?php

// Conexão com Oracle usando OCI
$user='contrx'; // seta o usuário
$pass='controlx123'; // seta a senha
$db='TOROMA =
(DESCRIPTION =
  (ADDRESS = (PROTOCOL = TCP)(HOST = 10.10.10.177)(PORT = 1521))   
  (ADDRESS = (PROTOCOL = TCP)(HOST = 10.10.10.176)(PORT = 1521))
   (CONNECT_DATA =
      (SERVER = DEDICATED)
      (SERVICE_NAME = t5db.toroma.local)
   )
)'; // Instância do banco de dados

$conn= @ocilogon($user,$pass,$db);

echo "Teste ok";

?>

Tentei também por PDO

<?php

class ConBD{
    
    private $ora_servidor = 'toroma';  // Servidor Oracle
    private $ora_user     = 'contrx'; // Usuario do banco
    private $ora_senha    = 'controlx123'; // Senha do banco
    private $ora_conecta;
    private $sql;
    private $resultado;
    
    
    private function AbriConexao() {
        
        $this->ora_conecta = ocilogon($this->ora_user,$this->ora_senha,$this->ora_servidor);
        if(!$this->ora_conecta) {
            echo "<p>Não foi possivel conectar-se ao servidor Oracle.</p>\n" 
                 .
                 "<p><strong>Erro Oracle: " . OCIError() . "</strong></p>\n";
                 echo "ok";
                 exit();
        } 
    }
    
    public function processa($sql){
        
        $this->AbriConexao();
        
        $this->sql = $sql;
        
        $this->resultado = OCIParse($this->ora_conecta, $this->sql);
            
        if(OCIExecute($this->resultado)){
            $this->fecharConexao();
            return $this->resultado;
        }  else {
            exit("<p>Erro Oracle: " . OCIError() . "</p>");
            $this->fecharConexao();
            
        }

    }
    
    private function fecharConexao() {
        return ocilogoff($this->ora_conecta);
    }

}

?>

 

Share this post


Link to post
Share on other sites

Ah sim já tirei o comentário das extensão do OCI no php.ini

 

extension=php_oci8_11c.dll  ; Use with Oracle Database 12c Instant Client
extension=php_oci8_11g.dll
extension=php_oracle.dll
extension=php_oci8.dll
extension=php_pdo.dll
extension=php_pdo_oci.dll
;extension=php_openssl.dll
;extension=php_pdo_firebird.dll
extension=php_pdo_mysql.dll
extension=php_pdo_oci.dll
;extension=php_pdo_odbc.dll
;extension=php_pdo_pgsql.dll
extension=php_pdo_sqlite.dll
;extension=php_pgsql.dll
;extension=php_shmop.dll

Share this post


Link to post
Share on other sites

Você já liberou o acesso?

faz um teste assim...

<?php

function conexao() {
$banco = 'nome_banco';
$usuario = 'nome_user';
$senha = 'senha';
$host = 'IP da Host';

$conn = mysql_connect($host,$usuario,$senha) ;
}
conexao();

 

Edited by Gabriel Heming
adicionar marcação de código

Share this post


Link to post
Share on other sites

Qual o erro que aparece quando você tenta se conectar?

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 Caio Vargas
      Fala pessoal como estOu criando um ecommerce estou com uma dúvida de como criar um filtro de produtos igual a desse site aqui 
      https://www.charmefitness.com.br/produtos/moda-fitness ele já vem marcado a categoria que está e já pega todos os itens daquela categoria alguém tem algo assim ou já fez 
       
       
    • By mateus.andriollo
      Tenhos duas tabelas Cab e Itm, gostaria de listar s sequencia de cab e inserir em um array os itens pertencentes a elas, compo incomum idcab.
       
      Não consigo fazer, o array será para json
    • By Wyrv
      Boa tarde pessoal, 

      Sou meio novo em programação web.
      Estou com o seguinte problema, qualquer ajuda será bem vinda.

      Em PHP, etou montando uma URL pra ser acessada com o comando Curl. 
      Tudo está funcionando, consigo executar e receber o retorno da URL no meu script.

      Porém o retorno parece vir em html, e a resposta que eu quero estar está no meio de tudo.
       
      <form name="IntegracaoForm" method="post" action="/integracao.do;jsessionid=C221B55C9AF93E1A94403FAA52943FB0" enctype="multipart/form-data" id="IntegracaoForm"> <table > <tbody> <tr> <td> 000 </td> </tr> </tbody> </table> </form><br>FIM<br>-> <br /> O código de retorno vem onde está o 000.
      No caso eu preciso validar esse retorno, mas eu não estou conseguindo uma forma de jogar esse valor pra uma variável pra realizar um if.

      Alguém pode me dar alguma ideia?

      Agradeço desde já.
       
    • By joao b silva
      amigos é o seguinte, eu crio um grid dinamicamente com bootstrap, porem a depender do conteúdo as colunas, na mesma linha ficam com tamanhos (height) diferentes, o que não acontece quando utilizamos <table></table>. Como posso resolver isso?
    • By Pellegrini2106
      Fala galera estou com uma duvida tenho um código em php  onde a classe e o método são passados por uma query string onde ele e passado desta forma:
      "http://localhost/projeto/?url=pessoa&metodo=cadastrarPessoa&id=1".
      Mas na verdade quero passar na forma de URL amigável pegando ao invés o arquivo pegasse  a classe e o método deste jeito "http://localhost/projeto/pessoa/cadastrarPessoa ou se tiver uma consulta pegando a classe, método e o resultado da consulta via URL  desta forma: "http://localhost/projeto/pessoa/1.
       
      Obrigado
       
      Olha o Código Fonte:
       
      .htaccess
      RewriteEngine On RewriteCond %{REQUEST_FILENAME} !-f RewriteCond %{REQUEST_FILENAME} !-d RewriteRule ^(.*)$ index.php?url=$1 [QSA,L] index.php
       
      <?php /* Chama a Biblioteca Gerenciadora de Template TWIG */ require_once 'vendor/autoload.php'; /* Classe Core */ require_once 'app/core/Core.php'; /* Classe Controle */ require_once 'app/controle/menuControle.php'; require_once 'app/controle/pessoaControle.php'; require_once 'app/controle/erroControle.php'; $template = file_get_contents("app/visao/template/estrutura.php"); ob_start(); $core = new Core(); $core->Start($_GET); $saida = ob_get_contents(); ob_end_clean(); $tplPronto = str_replace('{{Area Dinamica}}', $saida, $template); echo $tplPronto; Core.php -> E a camada onde eu quero transformar a query string em URL amigavél que por sua vez chama a classe controle.
      <?php class Core { public function Start($urlGet) { $acao = 'index'; if (isset($urlGet['url'])) { $controle = $urlGet['url'] . 'Controle'; } else { $controle = 'menuControle'; } if (!class_exists($controle)) { $controle = "erroControle"; } if (isset($urlGet['metodo'])) { $acao = $urlGet['metodo']; } else { $acao = 'index'; } call_user_func(array(new $controle, $acao), array()); } }  
       
×

Important Information

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