Jump to content

Assista click.png tectoy.png

C6 chamada_c6.png botao.png

Salvar XML CfeCanc no banco de dados


Go to solution Solved by José M. S. Junior,

Recommended Posts

  • Membros Pro

Boa tarde,

Estou salvando o xml de cancelamento do SAT no banco de dados, mas o mesmo esta sendo salvo sem a informação <?xml version="1.0"?> .

image.thumb.png.4c9e46892bd68d1ff0704c2520bb6486.png

Estou salvando da seguinte forma (igual faço com o xml da venda):  

Qry.ParamByName('xml').AsMemo:= UTF8Encode(DmSat.ACBrSAT.CFeCanc.AsXMLString);

Pode me ajudar ? O que estou fazendo errado ?

Link to comment
Share on other sites

  • Membros Pro

Bom dia Daniel.

Estou usando o emulador mesmo.

Faço a venda e salva corretamente no meu banco, mas no cancelamento esta salvando sem o <?xml version="1.0"?> .

Segue anexo o xml e o ACBrSat. Aparentemente esta tudo correto, só não sei o que eu estou fazendo errado.

Cfe35220311111111111111591234567890006116129190.xml ACBrSAT.log

Link to comment
Share on other sites

  • Membros Pro

Daniel,

Dei uma malhetada (Se é que vc me entende) e deu certo por enquanto:

Qry.ParamByName('xml').AsMemo:= UTF8Encode('<?xml version="1.0"?>' + DmSat.ACBrSAT.CFeCanc.AsXMLString);

Dessa maneira salva corretamente no banco de dados.

Link to comment
Share on other sites

  • Fundadores

Estou fora do PC.. mas pelo Log, poderíamos decodificar o retorno em Base64 e ver como o XML vem

1 hora atrás, marcellocainelli disse:

Daniel,

Dei uma malhetada (Se é que vc me entende) e deu certo por enquanto:

Qry.ParamByName('xml').AsMemo:= UTF8Encode('<?xml version="1.0"?>' + DmSat.ACBrSAT.CFeCanc.AsXMLString);

Dessa maneira salva corretamente no banco de dados.

Pode ser arriscado... pois eu acho que os SATs já retornam com a Declaração do XML...

Em todo caso, há um método na ACBrUtil que adiciona a Verificação apenas se ela não existir

Consultor SAC ACBr

Daniel Simões de Almeida
O melhor TEF, é com o Projeto ACBr - Clique e Conheça
Ajude o Projeto ACBr crescer - Assine o SAC

Projeto ACBr     Telefone:(15) 2105-0750 WhatsApp(15)99790-2976.

Link to comment
Share on other sites

  • Consultores

O XML do Cancelamento não fica na propriedade .XML quando ele está concluído e autorizado?

esse workarround que você fez pode resolver seu caso, mas era para o componente no loader já fazer isso.

Vou verificar essa questão do loader com o Ítalo, pode ser que a declaração só está sendo incluída em outro momento, teria que debugar o fluxo.

Consultor SAC ACBr

Victor H Gonzales - Pandaaa
Ajude o Projeto ACBr crescer - Assine o SAC

Projeto ACBr     Telefone:(15) 2105-0750 WhatsApp(15)99790-2976.  Discord

Projeto ACBr - A maior comunidade Open Source de Automação Comercial do Brasil

Participe de nosso canal no Discord e fique ainda mais próximo da Comunidade !!

"Aprender é a única coisa que a mente nunca se cansa, nunca tem medo e nunca se arrepende” - Leonardo da Vinci

"Ter sucesso é falhar repetidamente, mas sem perder o entusiasmo"

Link to comment
Share on other sites

  • Fundadores

Se você abrir uma das respostas, pode notar que o próprio Emulador está devolvendo o XML, se a declaração (parece ser um Bug do Emulador)

25/03/22 08:38:40:971 - NumeroSessao: 423251 - Comando: CancelarUltimaVenda( CFe35220311111111111111591234567890006104485540, <?xml version="1.0" encoding="UTF-8"?><CFeCanc><infCFe chCanc="CFe35220311111111111111591234567890006104485540"><ide><CNPJ>11111111111111</CNPJ><signAC>1111111111111222222222222221111111111111122222222222222111111111111112222222222222211111111111111222222222222221111111111111122222222222222111111111111112222222222222211111111111111222222222222221111111111111122222222222222111111111111112222222222222211111111111111222222222222221111111111111122222222222222111111111111112222222222222211111222</signAC><numeroCaixa>001</numeroCaixa></ide><emit></emit><dest></dest><total></total></infCFe></CFeCanc> )
25/03/22 08:38:45:018 - NumeroSessao: 423251 - Resposta:423251|07000||Cancelado com sucesso + conte?do notas|||
PENGZUNhbmM+PGluZkNGZSBJZD0iQ0ZlMzUyMjAzMTExMTExMTExMTExMTE1OTEyMzQ1Njc4OTAw
....

 

 

image.png

Consultor SAC ACBr

Daniel Simões de Almeida
O melhor TEF, é com o Projeto ACBr - Clique e Conheça
Ajude o Projeto ACBr crescer - Assine o SAC

Projeto ACBr     Telefone:(15) 2105-0750 WhatsApp(15)99790-2976.

Link to comment
Share on other sites

  • Membros Pro

Boa tarde.

O xml na pasta é salvo corretamente.

A questão é quando salvo no meu banco de dados. Dai vem sem o <?xml version="1.0"?>.

Somente consegui resolver salvando assim: 

Qry.ParamByName('xml').AsMemo:= InserirDeclaracaoXMLSeNecessario(DmSat.ACBrSAT.CFeCanc.AsXMLString);

Não consigo fazer o teste de salvar no meu banco usando o SATTeste.

Link to comment
Share on other sites

  • Consultores
29 minutos atrás, marcellocainelli disse:

Boa tarde.

O xml na pasta é salvo corretamente.

A questão é quando salvo no meu banco de dados. Dai vem sem o <?xml version="1.0"?>.

Somente consegui resolver salvando assim: 

Qry.ParamByName('xml').AsMemo:= InserirDeclaracaoXMLSeNecessario(DmSat.ACBrSAT.CFeCanc.AsXMLString);

Não consigo fazer o teste de salvar no meu banco usando o SATTeste.

Não precisa salvar no seu banco, pegue a lógica e jogue em um Memo o resultado

Consultor SAC ACBr

Victor H Gonzales - Pandaaa
Ajude o Projeto ACBr crescer - Assine o SAC

Projeto ACBr     Telefone:(15) 2105-0750 WhatsApp(15)99790-2976.  Discord

Projeto ACBr - A maior comunidade Open Source de Automação Comercial do Brasil

Participe de nosso canal no Discord e fique ainda mais próximo da Comunidade !!

"Aprender é a única coisa que a mente nunca se cansa, nunca tem medo e nunca se arrepende” - Leonardo da Vinci

"Ter sucesso é falhar repetidamente, mas sem perder o entusiasmo"

Link to comment
Share on other sites

  • Consultores
33 minutos atrás, marcellocainelli disse:

Boa tarde.

O xml na pasta é salvo corretamente.

A questão é quando salvo no meu banco de dados. Dai vem sem o <?xml version="1.0"?>.

Somente consegui resolver salvando assim: 

Qry.ParamByName('xml').AsMemo:= InserirDeclaracaoXMLSeNecessario(DmSat.ACBrSAT.CFeCanc.AsXMLString);

Não consigo fazer o teste de salvar no meu banco usando o SATTeste.

Entendido, vamos verificar, simulando dessa forma...

Consultor SAC ACBr

José Junior
Ajude o Projeto ACBr crescer - Assine o SAC

Projeto ACBr     Telefone:(15) 2105-0750 WhatsApp(15)99790-2976.

Link to comment
Share on other sites

  • 2 weeks later...
  • Consultores
  • Solution

Boa tarde @marcellocainelli,

Analisando os fontes notamos que o retorno da property AsXMLString é o XML original retornado pelo SAT e no caso do emulador de fato está retornando sem o Encode UTF8 o retorno em base64. Uma outra forma de obter o XML convertido para UTF8 do próprio componente é obtendo o retorno direto do método GerarXML, esse método já faz a conversão. ex:  ACBrSAT1.CFeCanc.GerarXML()

Consultor SAC ACBr

José Junior
Ajude o Projeto ACBr crescer - Assine o SAC

Projeto ACBr     Telefone:(15) 2105-0750 WhatsApp(15)99790-2976.

Link to comment
Share on other sites

  • Consultores

Obrigado por reportar.

Fechando. Para novas dúvidas, criar um novo tópico.

Consultor SAC ACBr

Victor H Gonzales - Pandaaa
Ajude o Projeto ACBr crescer - Assine o SAC

Projeto ACBr     Telefone:(15) 2105-0750 WhatsApp(15)99790-2976.  Discord

Projeto ACBr - A maior comunidade Open Source de Automação Comercial do Brasil

Participe de nosso canal no Discord e fique ainda mais próximo da Comunidade !!

"Aprender é a única coisa que a mente nunca se cansa, nunca tem medo e nunca se arrepende” - Leonardo da Vinci

"Ter sucesso é falhar repetidamente, mas sem perder o entusiasmo"

Link to comment
Share on other sites

Guest
This topic is now closed to further replies.
×
×
  • Create New...

Important Information

We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.