quinta-feira, 18 de fevereiro de 2016

Como assinar documento XML com assinaturas digitais em Windev - leonardo vilani



http://leonardo-vilani.blogspot.com.br/2016/02/como-assinar-documento-xml-com.html



Video do Leonardo Villani sobre Xml



Como assinar documento XML com assinaturas digitais em Windev

Olá pessoal, recentemente inciamos um projeto para emissão de NFe Web, como gostamos de ganhar tempo sempre que possível procuramos reaproveitar outros projetos, ou até mesmo usar recursos FREE disponíveis na internet, para esse caso optamos por usar o NFePHP, com ele conseguimos economizar tempo com várias rotinas como Status do Serviço, Validar XML, Assinar XML, Enviar XML, Enviar Lote, Validar NFe..... sabemos que no Webdev temos rotinas que facilitam trabalhos como consumir WS, criar XML... mas apesar de ter as funções  para manipulação e assinaturas de arquivos com certificado digital não encontramos uma forma de assinar um XML diretamente com elas, apesar de ter pronto esse recurso para web com PHP,  resolvi investir em uma forma de conseguir esse resultado sem uso de controles ou componentes de terceiros, assim teria certeza de que é possível desenvolver uma solução 100% independente,. Navegando pelo site da PCSoft observei que saiu na LST 103 um exemplo de assinatura em XML usando .NET então a lampada acendeu e resolvi dar uma pesquisada sobre isso, acabei descobrindo que posso fazer muito mais do que imaginava com esse recurso, e resolvi postar esse pequeno exemplo mas que pode ampliar e muito nossas possibilidades dentro do windev/webdev. Bom vamos la:


1) Crie um projeto no Windev e adicione os Assemblies .NET




2) Crie um form com um botão, no código do botão inclua o seguinte código:


//1 - Criar um CspParameters do objeto e especifique o nome do contêiner de chave.
cspParams is CspParameters();
cspParams.KeyContainerName = "XML_DSIG_RSA_KEY";

//2 - Gerar uma chave assimétrica usando oRSACryptoServiceProviderclasse.A chave é salvo automaticamente para o 
// contêiner de chave quando você passa oCspParametersao construtor daRSACryptoServiceProviderclasse.Essa chave será usada para assinar o documento XML.
RsaKey is RSACryptoServiceProvider(cspParams);

//3 - Criar umXmlDocumentobjeto carregando um arquivo XML do disco.OXmlDocumentobjeto contém o elemento XML para criptografar.
XmlDoc is System.Xml.XmlDocument();
XmlDoc.PreserveWhitespace = True;
XmlDoc.Load("test.xml");

//4 - Criar um novoSignedXmlobject e passar oXmlDocumentobjeto nele.
SignedXml is SignedXml(XmlDoc);

//5 - Adicionar a chave de assinatura RSA para oSignedXmlobjeto.
SignedXml.SigningKey = RsaKey;

//6 - Criar umReferenceobjeto que descreve o que assinar.Para assinar o documento inteiro, defina aUripropriedade"".
reference is Reference();
reference.set_Uri("");

//7 - Adicione umXmlDsigEnvelopedSignatureTransformdo objeto para oReferenceobjeto.Uma transformação permite que o 
// verificador representar os dados XML da maneira idênticas que o signatário usado.Dados XML podem ser representados 
// de diversas maneiras, essa etapa é vital para verificação.
Env is XmlDsigEnvelopedSignatureTransform();
reference.AddTransform(Env);

//8 - Adicionar oReferencedo objeto para oSignedXmlobjeto.
SignedXml.AddReference(reference);

//9 - Compute a assinatura ao chamar oComputeSignaturemétodo.
SignedXml.ComputeSignature();

//10 - Recuperar a representação XML da assinatura (um <Signature> elemento) e salvá-lo em um novoXmlElementobjeto.
XmlDoc.DocumentElement.AppendChild(XmlDoc.ImportNode(SignedXml.GetXml(), True));

//11 - Acrescente o elemento para oXmlDocumentobjeto.
XmlDoc.Save("test_ass.xml");


Pronto basta incluir um XML qualquer na pasta EXE do projeto e renomeá-lo para TEST.XML, ao clicar no botão será criado outro arquivo com nome de TEST_ASS.XML

Espero que ajude a vocês esclarecerem dúvidas como a minha e ampliem seus horizontes assim como ocorreu comigo, se observarem o código é praticamente um C# puro. Devemos disponibilizar nos próximos dias um exemplo de assinatura usando o certificado digital A1 para ser utilizado na NFe.






Nenhum comentário:

Postar um comentário

Teste

Teste
teste