Jump to content
Matheus Brito

Dá para resolver esse problema com PHP?

Recommended Posts

Boa noite a todos. Seguinte, tenho um sistema em php que  chama um script python e ao final esse script gera um arquivo de log, até ai ok, porém o arquivo de log está saindo com uma codificação maluca em algumas partes será que tem como resolver via PHP? Tentei ler o arquivo para o php e usar a função utf8_encode e nada.

 

Na imagem é possível perceber os quadrados, onde estão os quadrados deveriam ser valores.O script em python está correto não é erro lá não. Talvez alguma dependência ou versão do python da minha máquina tá fazendo gerar isso, porém já tentei solucionar testando diversas versões de tudo e não deu certo. Outro detalhe é que quando leio o arquivo em python ele mostra que onde tem os quadrados ele subsituti por \x1b...

 

Alguma ideia?

Captura de tela de 2017-04-13 19-41-49.png

Share this post


Link to post
Share on other sites

Matheus, vou falar meio que no escuro para tentar ajudar. Já faz um bom tempo que fiz um sistema que interagia com um switch via ssh e tenho lembranças vagas...
Então, esse hexadecimal \x1b se não me engano refere-se ao log do inpute da tecla ESC, se também bem me lembro o PHP não exibira esse valor, mas da você pode exibir o correspondente na tabela ASCII com a função  ord("\x1b"); caso precise

Talvez isso seja útil:
http://php.net/manual/pt_BR/regexp.reference.escape.php

Share this post


Link to post
Share on other sites
15 horas atrás, EdCesar disse:

Matheus, vou falar meio que no escuro para tentar ajudar. Já faz um bom tempo que fiz um sistema que interagia com um switch via ssh e tenho lembranças vagas...
Então, esse hexadecimal \x1b se não me engano refere-se ao log do impute da tecla ESC, se também bem me lembro o PHP não exibira esse valor, mas da você pode exibir o correspondente na tabela ASCII com a função  ord("\x1b"); caso precise

Talvez isso seja útil:
http://php.net/manual/pt_BR/regexp.reference.escape.php

Boa tarde EdCesar. Obrigado pela resposta. Seguinte eu testei essa função. Fiz um código simples para ler o arquivo e imprimir por linha. Realmente ela convere os códigos ascii em inteiros, mas acredito que os números não estão corretos, fiquei meio em dúvida.

 

segue código.

$fp = fopen("orientationLog.log", "r"); 

while(!feof($fp)) { 
    $linha = fgets($fp, 4096); 
    echo ord($linha)."\n"; 
}

E tive isso como resultado:

50 27 49 49 49 49 49 49 49 27 27 27 27 27 27 27 27 27 77 49 49 27 49 50 27

Realmente a contagem está certa, no arquivo de log existem 25 números. Mas de acordo com meus resultados não estou certo que os números estão corretos não, pode ser alguma coisa que ainda precisa ser feita?

 

Abraços,

Share this post


Link to post
Share on other sites

Matheus, joia!

Lembrando que a aspas simples trata tudo como string:
 

$caracter = "\x1b";
echo $caracter; // Exibira: � (Aquele quadradinho da imagem)

$caracter = '\x1b';
echo $caracter; // Exibira:  \x1b


No caso fazendo a leitura de um arquivo de log, para exibir a string \x1b, isso seria uma possibilidade:
 

$fp = fopen("orientationLog.log", "r"); 
while(!feof($fp)) { 
    $linha = str_replace("'","",escapeshellarg(fgets($fp, 4096))); 
    echo ($linha)."\n"; 
}


Se a sua questão for algo mais do que exibir a string \x1b, conte-nos um pouco mais o que você pretende fazer, pois no caso de logs como a tecla backspace, enter, esc etc... você só conseguira exibir o seu equivalente em hexadecimal, decimal, octal ou binário de acordo com a tabela ASCII

Para confirmar se os números estão vindo corretos, faça um "de para" na tabela abaixo:
https://pt.wikipedia.org/wiki/ASCII
por exemplo, 50 em decimal equivale à 32 em hexa, que seu log deve estar como \x32

Share this post


Link to post
Share on other sites
45 minutos atrás, EdCesar disse:

Matheus, joia!

Lembrando que a aspas simples trata tudo como string:
 


$caracter = "\x1b";
echo $caracter; // Exibira: � (Aquele quadradinho da imagem)

$caracter = '\x1b';
echo $caracter; // Exibira:  \x1b


No caso fazendo a leitura de um arquivo de log, para exibir a string \x1b, isso seria uma possibilidade:
 


$fp = fopen("orientationLog.log", "r"); 
while(!feof($fp)) { 
    $linha = str_replace("'","",escapeshellarg(fgets($fp, 4096))); 
    echo ($linha)."\n"; 
}


Se a sua questão for algo mais do que exibir a string \x1b, conte-nos um pouco mais o que você pretende fazer, pois no caso de logs como a tecla backspace, enter, esc etc... você só conseguira exibir o seu equivalente em hexadecimal, decimal, octal ou binário de acordo com a tabela ASCII

Para confirmar se os números estão vindo corretos, faça um "de para" na tabela abaixo:
https://pt.wikipedia.org/wiki/ASCII
por exemplo, 50 em decimal equivale à 32 em hexa, que seu log deve estar como \x32

 

Olá EdCesar, então não acho que tenha relação com esse problema no momento as aspas. Fiz a leitura do arquivo em python no terminal para que você veja, todos os números do relatório são codificados como \x1b, talvez por isso aquele resultado repetitivo dos 25 números que coloquei mais acima. Não sei achei que ia resolver com sua dica inicial, mas acho que não vai não. Se você olhar a figura verá que está o relatório todo do programa e na hora que deveria aparecer um número aparece o \x1b.

 

Testei a função que você colocou acima, mas nada mudou os números saíram os mesmos.

 

Abraços,

 

 

Captura de tela de 2017-04-15 00-24-47.png

Share this post


Link to post
Share on other sites

Matheus, tentei fazer uma simulação desse seu arquivo de log, e imprimiu a string referente a tecla ESC, em hexadecimal, tanto no terminal quanto no navegador, conforme o print

Seria apenas isso o que você quer fazer? Tirando os problemas, qual o seu objetivo?
 

caracter.png

Share this post


Link to post
Share on other sites

Olá EdCesar, então eu achei que essa codificação era de um número inteiro, era isso que eu queria fazer converter isso para o número real.

 

 

Abraços,

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 Sapinn
      Opa galera tudo beleza? Então meu banco está me retomando um erro quando tento inserir nele que é "Dados truncados na coluna valor_produto" essa coluna era do tipo Double quando eu mudei para ela para TEXT funcionou os dados foram inseridos mas eu preciso que ela seja do tipo double. Alguém sabe como resolver????
    • By k9studio
      Olá Amigos,
      se alguem puder dar um help fico muito grato
      seguinte:
      estou criando um sistema de login com cookie
      todas as paginas fica no patch
      www/htdocs/script/
      quando logar no dominio.com.br liberar o acesso no  cliente.dominio.com.br tambem
      acesso:dominio.com.br
      ou
      quando logar no cliente.dominio.com.br liberar o acesso no dominio.com.br tambem
      acesso:cliente.dominio.com.br
      e guando deslogar quebrar conxao com os dois
      existe uma maneira de fazer isso?
       
    • By Kefatif
      Prezados boa tarde.
       
      Preciso bloquear a edição de um date input de forma que só seja possível selecionar a data através do calendário.
       
      Alguém pode me ajudar?
       
      Utilizo php, html e js.
       
      <input type="date" value="<?php echo $data ?>" name="datacoleta" class="form-control" required style="width:100%;">  
      Agradeço desde já.
    • By Kefatif
      Prezados boa tarde.
       
      Preciso bloquear a edição de um date input de forma que só seja possível selecionar a data através do calendário.
       
      Alguém pode me ajudar?
       
      Utilizo php, html e js.
       
      <input type="date" value="<?php echo $data ?>" name="datacoleta" class="form-control" required style="width:100%;">  
      Agradeço desde já.
    • By Thiago Duarte
      Eu tenho uma página que abri um alert ao clicar no link , só que nao cadastra e nem funciona o login.
       
       <div class="btn-box">          <a class="btn btn-color venobox vbox-item" data-toggle="modal" href="javascript:void(0)" onclick="openRegisterModal();">Start now Free </a>             <img src="images/seta.png"> </div>  
      <div class="modal-body">                               <div class="box">                                  <div class="content">                                     <!-- Login Form -->                                     <div class="loginBox">                                        <form id="login-modal" role="form"  method="post" action="#">                                           <input type="hidden" name="param" value="logar" />                                           <!-- Success/Alert Notification -->                                           <p class="lm-success"><i class="icon icon_check_alt2"></i> <strong>Congratulation! Login modal validation is working. Implement your code.</strong></p>                                           <p class="lm-failed"><i class="icon icon_close_alt2"></i><strong> Something went wrong! Insert correct value.</strong></p>                                           <!-- Input Fields -->                                           <input id="lm-email" class="form-control input-lg" type="text" placeholder="Email" name="email" required="">                                           <input id="lm-password" class="form-control input-lg" type="password" placeholder="Password" name="senha" required="">                                           <!-- Login Button -->                                           <input type="submit" class="btn btn-color" value="Login">                                           <!-- <button class="btn btn-color">Login</button> -->                                        </form>                                     </div>                                     <!-- /End Login Form -->                                  </div>                               </div>                               <!-- /End Login Form Box -->                               <div class="box">                                  <!-- Signup Form -->                                  <div class="content registerBox" style="display:none;">                                     <form id="signup-modal" role="form" method="post" action="?go=cadastrar">                                        <!-- Success/Alert Notification -->                                        <p class="sm-success"><i class="icon icon_check_alt2"></i> <strong>Congratulation! Signup modal validation is working. Implement your code.</strong></p>                                        <p class="sm-failed"><i class="icon icon_close_alt2"></i><strong> Something went wrong! Insert correct value.</strong></p>                                        <!-- Input Fields -->                                        <input id="sm-email" class="form-control input-lg" type="text" placeholder="Email" name="email" required="">                                        <input id="sm-password" class="form-control input-lg" type="password" placeholder="password" name="password">                                        <input id="sm-confirm" class="form-control input-lg" type="password" placeholder="Repeat password" name="senha-confirm">                                        <!-- Signup Button -->                                        <!--  <button class="btn btn-color">Create an account</button> -->                                        <input type="submit" class="btn btn-color" value="Create an account">                                     </form>                                  </div>                                  <!-- /End Signup Form -->                               </div>                               <!-- /End Signup Form Box -->                            </div>  
      e em baixo do </html> coloquei
        <?php           $param = (empty($_POST['param'])) ? 'error' : $_POST['param'];           if($param == 'logar'){       //if($_POST['param'] == 'logar'){             $email = $_POST['email'];             $password = $_POST['password'];             $query1 = mysql_num_rows(mysql_query("SELECT * FROM usuario WHERE email = '$email' AND password = '$password'")) or die(mysql_error());             if($query1 == 1){           // print "<script>alert('logou');</script>";              print "<script>window.location.replace('dashboard/index.php');</script>";           }else{              echo "<script>alert('User and password do not match.'); history.back();</script>";           }        }        if(@$_GET['go'] == 'cadastrar'){           // $dominio_gratis = $_POST['dominio_gratis'];          $email = $_POST['email'];          $password = $_POST['password'];          $date_register = date("m-d-Y");                // if(empty($dominio_gratis)){           //     echo "<script>alert('Preencha todos os campos para se cadastrar.'); history.back();</script>";           // }else          if(empty($email)){           echo "<script>alert('Fill in all the fields to register.'); history.back();</script>";            }elseif(empty($password)){           echo "<script>alert('Fill in all the fields to register.'); history.back();</script>";        }else{           $query1 = mysql_num_rows(mysql_query("SELECT * FROM usuario WHERE email = '$email'"));           if($query1 == 1){            echo "<script>alert('User already exists.'); history.back();</script>";          }else{            mysql_query("insert into usuario (email, password, date_register, plan) values ('$email','$password','$date_register', '0')");            header("Location: dashboard/dashboard.php");         }      }   }   ?>  
      Alguem pode ajudar?
×

Important Information

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