Jump to content
OverMix

Head Soap - Como ler com PHP?

Recommended Posts

Prezados Amigos

 

Boa Tarde

 

Estou a consumir um WSDL de um Webservice onde após o login e após cada requisição conforme XML retornado abaixo me é apresentada as seguintes tags no head do Soap

 

<Sequencia>1</Sequencia>
<SessionId>4b4uc2536530-941f-44e6-ab95-8ee7179fb016</SessionId>
Como regra de segurança devo salvar estes e na próxima requisão usar os dados para a próxima requisição gravar, nesta nova requisição sera gerada nova sessão e sequencia e eu devo guarda-las para outra requisição e assim por diante.
<?xml version="1.0" encoding="utf-8"?>
<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
    <soap:Header>
        <Sessao xmlns="http://dominio.com.br">
            <Sequencia>1</Sequencia>
            <SessionId>4b4uc2536530-941f-44e6-ab95-8ee7179fb016</SessionId>
            <Versao>
                <Id>1</Id>
                <SituacaoCache>Inalterado</SituacaoCache>
                <VersaoAtual>0</VersaoAtual>
                <ReleaseAtual>0</ReleaseAtual>
                <ProximaAtualizacao>0001-01-01T00:00:00</ProximaAtualizacao>
                <Minutos>0</Minutos>
                <VersaoDisponivel>
                    <VersaoRota>0</VersaoRota>
                    <VersaoBanco>0</VersaoBanco>
                    <ReleaseBanco>0</ReleaseBanco>
                    <Compilacao>0</Compilacao>
                </VersaoDisponivel>
                <QuantidadeReleases>0</QuantidadeReleases>
            </Versao>
        </Sessao>
    </soap:Header>
    <soap:Body>
        <LogOnResponse xmlns="http://dominio.com.br">
            <LogOnResult>
                <Excecoes />
                <DatabaseCount>0</DatabaseCount>
                <Retorno>
                    <Id>18659</Id>
                    <Nome>NOME</Nome>
                    <Email>nome@provedor.com</Email>
                    <Endereco />
                    <Bairro />
                    <Cidade />
                    <Estado />
                    <Pais />
                    <Cep />
                    <LogOn>login</LogOn>
                    <DataNascimento>1984-09-17T00:00:00</DataNascimento>
                    <RG />
                    <Cpf>000.000.000-00</Cpf>
                    <Telefone />
                    <Celular />
                    <Configuracoes />
                    <Ativo>true</Ativo>
                    <Tema>Azul</Tema>
                    <Perfil>
                        <Id>12</Id>
                        <Nome>Sites Externos</Nome>
                        <Descricao />
                        <NiveisAcesso>
                            <CLPerfilNivelAcesso>
                                <Id>11</Id>
                                <Perfil>
                                    <Id>12</Id>
                                    <Nome>Sites Externos</Nome>
                                    <Descricao />
                                    <NiveisAcesso />
                                    <Modulos />
                                    <Atividades />
                                </Perfil>
                                <NivelAcesso>
                                    <Id>1</Id>
                                    <Nome>Usuário</Nome>
                                    <Codigo>1</Codigo>
                                    <Descricao />
                                </NivelAcesso>
                            </CLPerfilNivelAcesso>
                        </NiveisAcesso>
                        <Modulos>
                            <CLPerfilModulo>
                                <Id>19</Id>
                                <Perfil>
                                    <Id>12</Id>
                                    <Nome>Sites Externos</Nome>
                                    <Descricao />
                                    <NiveisAcesso />
                                    <Modulos />
                                    <Atividades />
                                </Perfil>
                                <Modulo>
                                    <Id>9</Id>
                                    <Nome>Portais</Nome>
                                    <Codigo>256</Codigo>
                                    <Descricao />
                                </Modulo>
                            </CLPerfilModulo>
                            <CLPerfilModulo>
                                <Id>20</Id>
                                <Perfil>
                                    <Id>12</Id>
                                    <Nome>Sites Externos</Nome>
                                    <Descricao />
                                    <NiveisAcesso />
                                    <Modulos />
                                    <Atividades />
                                </Perfil>
                                <Modulo>
                                    <Id>2</Id>
                                    <Nome>Processos</Nome>
                                    <Codigo>2</Codigo>
                                    <Descricao />
                                </Modulo>
                            </CLPerfilModulo>
                        </Modulos>
                        <Atividades />
                    </Perfil>
                    <Skype />
                    <EmpresaAtual>
                        <Id>0</Id>
                        <SituacaoCache>Inalterado</SituacaoCache>
                        <Nome />
                        <RazaoSocial />
                        <Cnpj />
                        <Endereco />
                        <Bairro />
                        <Cidade />
                        <Estado />
                        <Pais />
                        <Cep />
                        <SistemaWooba>
                            <Id>0</Id>
                            <SituacaoCache>Inalterado</SituacaoCache>
                            <Codigo />
                            <Nome />
                            <Wooba>0</Wooba>
                            <Observacoes />
                            <TemBilhetes>true</TemBilhetes>
                            <PermiteBilheteSemLocalizador>false</PermiteBilheteSemLocalizador>
                            <Campos />
                        </SistemaWooba>
                        <SistemaSisav>
                            <Id>0</Id>
                            <SituacaoCache>Inalterado</SituacaoCache>
                            <Codigo />
                            <Nome />
                            <Wooba>0</Wooba>
                            <Observacoes />
                            <TemBilhetes>true</TemBilhetes>
                            <PermiteBilheteSemLocalizador>false</PermiteBilheteSemLocalizador>
                            <Campos />
                        </SistemaSisav>
                        <Arquivo>
                            <Nome />
                            <Extensao />
                            <Hash />
                            <Conteudo />
                        </Arquivo>
                    </EmpresaAtual>
                    <DeveAlterarSenha>false</DeveAlterarSenha>
                    <SenhaNuncaExpira>false</SenhaNuncaExpira>
                    <DataAlteracaoSenha>2015-11-10T14:53:45.647</DataAlteracaoSenha>
                    <DataAlteracaoEmail>0001-01-01T00:00:00</DataAlteracaoEmail>
                    <DataAlteracaoCelular>0001-01-01T00:00:00</DataAlteracaoCelular>
                    <Perguntas>0</Perguntas>
                    <UsaBloqueioIP>false</UsaBloqueioIP>
                    <JornadaTrabalho>
                        <Id>0</Id>
                        <Nome />
                        <Prioridade>0</Prioridade>
                    </JornadaTrabalho>
                    <Sexo>Masculino</Sexo>
                    <TokenSSO />
                    <Arquivo>
                        <Nome />
                        <Extensao />
                        <Hash />
                        <Conteudo />
                    </Arquivo>
                </Retorno>
            </LogOnResult>
        </LogOnResponse>
    </soap:Body>
</soap:Envelope>
<pre>

em testes o código PHP abaixo ao ser executado me apresenta a seguinte mensagem

XML não existe

$UrlWSLogin = new SoapClient('https://ws.dominio.com.br/integrador/integrador.asmx?WSDL', array('trace' => 1));
//print_r($UrlWS->__getFunctions());

$MetodoLoginWS = 'LogOn';

$DadosLoginWs = array(
    "Sequencia" => "0",
    "SessionId" => "0",
    "prUsuario" => "login",
    "prSenha" => "senha",
);

$ResultadoWS = $UrlWSLogin->$MetodoLoginWS($DadosLoginWs);

//$RespostaWS = '<pre>'.print_r($ResultadoWS,true).'</pre>';

if (isset($ResultadoWS)) {
    //echo '<pre>'. print_r($UrlWSLogin->__getLastResponse());'</pre>';
    
    $XMLws = $UrlWSLogin->__getLastResponse(); // usando __getLastResponse tenho acesso ao header do soap

    if (!$xml = simplexml_load_string("$XMLws")) {
        echo 'XML não existe';
    } else {
        echo $xml->Sessao->SessionId;
    }
    
    echo "Falha ao capturar xml do ws";
}

Teria algum tratamento para que eu possa converter as tags do objeto em variaveis assim podendo trabalhar mais fácil com eles?

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 gersonab
      bom dia.
      estou com um problema aqui, quando vou fazer update de uma página com dados vindos do banco os select option mostra os dados corretamente porém os value capturados não estão corretos, um exemplo, se for de cidades vem no value somente o primeiro nome da cidade enquanto na exibição do nome vem completo, logo, quando faço o update grava somente o primeiro nome, pois esta se dividindo e criando campos.
      <select class="form-control" name="cidade"> <option value="">-- Selecionar --</option> <?php $curc4 = $pdo->query("SELECT * FROM comarca ORDER BY comarc asc"); while ($lic4 = $curc4->fetch(PDO::FETCH_ASSOC)) { echo "<option value=".$lic4['comarc']." ".($cidade == $lic4['comarc'] ? "selected":"")." >".$lic4['comarc']."</option>"; } ?> </select> como é mostrado no console:
      <option value="ANGRA" dos="" reis="">ANGRA DOS REIS</option> desde já agradeço ajuda
    • By unset
      Olá, alguém poderia me dar uma luz.
       
      Como faço para ordenar strings que começam com números, exemplo
       
      Tenho uma lista de artigos e os nomes são como abaixo.
       
      1 - NOME DO ARQUIVO 1
      2 - NOME DO ARQUIVO 2
      etc....
      10 - NOME DO ARQUIVO 10
       
      Não consegui ordenar no SELECT com o ORDER BY nome DESC pq o número 10 fica abaixo do 1
       
      Como fazer assim, 1,2,3,4,5....... 10,11,12 .... 100, 101,102 etc...
    • By Rodrigo5468
      Olá a todos(as), boa tarde!
       
      Tenho uma Query e um pequeno código em PHP para mostrar os resultados em uma tabela, mas estão repetindo os resultados da Query. Gostaria de uma solução, ou uma gambiarra para isso.
      Query
      SELECT DISTINCT b.ID AS "ID", b.Character AS "Personagem", b.Money AS "DinMao", b.BankMoney AS "DinBanco", b.Savings2 AS "DinPoupa", c.houseOwner AS "IDono", SUM(c.houseMoney) AS "DinCasa" FROM characters b INNER JOIN houses c ON (b.ID = c.houseOwner) ORDER BY ((b.Money+b.BankMoney+b.Savings2+c.houseMoney)) DESC LIMIT 0, 1000 PHP
      if(mysqli_num_rows($q) > 0) { while($r = $q->fetch_assoc()) { //Código da Tabela } }  
      Observação:
      Quando eu removo a seguinte parte da minha Query que é: SUM(c.houseMoney) AS "DinCasa" e deixo assim: c.houseMoney AS "DinCasa"
      Os dados da minha tabela repetem, não sei o motivo e/ou a circunstância disso. Mas peço a ajuda de vocês para solucionar. Vale ressaltar que (ID e houseOwner) tem os mesmos valores, só o valor da casa que recebe o valor do ID, e ele pode ter quantas casa ele quiser, e se ele tiver cinco casas, mostrará o resultado cinco resultados na minha tabela, como posso resolver isso?
       
       
      Meu muito obrigado desde já.
    • By guilhermefdavid
      Olá,
      tenho uma aplicação PHP com algumas funções que não estão funcionando na hospedagem.
      Esta aplicação utiliza apenas conexão com banco de dados -> mysql_connect, mysql_select_db, entre outras de MYSQL.
      Alguma ideia de qual extensão, dentre as existentes na imagem anexa deveria(m) estar ativada(s)?
       
      Um abraço!

    • By jganjos
      Boa tarde senhores.
      Estou gerando esta array com o PHP
       
      Array ( [header] => Array ( [ico] => fas fa-building [tit] => Empresa [lab] => Cadastro da Empresa ) [forms] => Array ( [RAZAO] => Array ( [tit] => Razão Social ) [NFANTASIA] => Array ( [tit] => Nome Fantasia [lin] => 1 [col] => 10 ) [STATUS] => Array ( [tit] => Status [typ] => switch [val] => 1,0 [lin] => 1 [col] => 2 ) [INSCRICAO] => Array ( [tit] => Inscrição [lin] => 2 [col] => 4 ) [IE] => Array ( [tit] => Insc. Estadual [lin] => 2 [col] => 4 ) [IM] => Array ( [tit] => Insc. Municipal [lin] => 2 [col] => 4 ) [CEP] => Array ( [tit] => CEP [lin] => 3 [col] => 4 [btn] => search ) [TIPO_END] => Array ( [typ] => hidden ) [ENDERECO] => Array ( [tit] => Endereço [lin] => 4 [col] => 9 ) [NUM_END] => Array ( [tit] => Número [lin] => 4 [col] => 3 ) [BAIRRO] => Array ( [tit] => Bairro [lin] => 5 [col] => 6 ) [COMPL] => Array ( [tit] => Complemento [lin] => 5 [col] => 6 ) [MUNICIPIO] => Array ( [tit] => Município [lin] => 6 [col] => 9 ) [UF] => Array ( [tit] => Estado [typ] => list [tab] => estados [lin] => 6 [col] => 3 ) [TEL1] => Array ( [tit] => Telefone [msk] => phone [lin] => 7 [col] => 6 ) [TEL2] => Array ( [tit] => Telefone [msk] => phone [lin] => 7 [col] => 6 ) [EMAIL] => Array ( [tit] => e-mail [typ] => email [lin] => 8 [col] => 6 ) [SITE] => Array ( [tit] => Site da empresa [typ] => website [lin] => 8 [col] => 6 ) ) ) Preciso listar os valores da Array *FORMS* e seus respectivos filhos mas não estou conseguindo utilizando o foreach.
      Alguém teria uma dica?
×

Important Information

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