1. java
  2. android
  3. c#
  4. .net
  5. javascript
  6. php
  7. jquery
  8. html
  9. sql

Assinatura Digital PDF

Boa Noite galera, tudo bem? Sou nova por aqui.

Estou desenvolvendo um código para assinar PDF. Ele funciona, porém somente na primeira excução. Depois trava o software do token ou o load do Keystore.

Segue código:

public class AssinaturaDigital { public void sign(String src, String dest, Certificate[] chain, PrivateKey pk, String digestAlgorithm, String provider, CryptoStandard subfilter, String reason, String location, Collection<CrlClient> crlList, OcspClient ocspClient, TSAClient tsaClient, int estimatedSize) ```throws GeneralSecurityException, IOException, DocumentException {

PdfSignatureAppearance appearance = null; PdfReader reader = new PdfReader(src); FileOutputStream os = new FileOutputStream(dest); PdfStamper stamper = PdfStamper.createSignature(reader, os, '\0');

try {

appearance = stamper.getSignatureAppearance(); appearance.setReason(reason); appearance.setLocation(location);

appearance.setVisibleSignature(new Rectangle(20, 1, 144, 30),1,null); ExternalSignature pks = newPrivateKeySignature(```pk,digestAlgorithm,"SunMSCAPI");```

ExternalDigest digest = new BouncyCastleDigest();

MakeSignature.signDetached(appearance, digest, pks, chain, crlList, ocspClient, tsaClient, estimatedSize, subfilter); } catch (GeneralSecurityException ex) { System.out.println("ERROR " + ex.getMessage()); } catch (DocumentException ex) { System.out.println("ERROR " + ex.getMessage()); } catch (IOException ex) { System.out.println("ERROR " + ex.getMessage()); } catch (Exception e) { e.printStackTrace(); System.out.println("ERROR " + e.getMessage()); } finally { stamper.close(); os.close(); reader.close(); Security.removeProvider(provider); } }

public static void main(String[] args) throws Exception { PrivateKey pk = null; Certificate[] chain = null; BouncyCastleProvider providerBC = null; if (args.length > 0) { String source = args[0]; String destination = args[1]; try { LoggerFactory.getInstance().setLogger(new SysoLogger()); providerBC = new BouncyCastleProvider(); Security.addProvider(providerBC);

KeyStore ks = KeyStore.getInstance("Windows-MY", "SunMSCAPI"); String keystore_password = "malaga@88"; ks.load(null, null); //ks.load(null, keystore_password.toCharArray()); System.out.println(keystore_password.toCharArray()); String alias = (String) ks.aliases().nextElement(); pk = (PrivateKey) ks.getKey(alias, null);

//Provider p = ks.getProvider(); // Security.addProvider(p); chain = ks.getCertificateChain(alias);

TSAClient tsaClient = null;

for (int i = 0; i < chain.length; i++) { X509Certificate cert = (X509Certificate) chain[i]; String tsaUrl = CertificateUtil.getTSAURL(cert); if (tsaUrl != null) { tsaClient = new TSAClientBouncyCastle(tsaUrl); break; }

}

List<CrlClient> crlList = new ArrayList<CrlClient>(); crlList.add(new CrlClientOnline(chain)); AssinaturaDigital app = new AssinaturaDigital(); app.sign(source, destination, chain, pk, DigestAlgorithms.SHA256, providerBC.getName(), CryptoStandard.CMS, "Teste", "SP", null, null, tsaClient, 0); } catch(Exception e) { System.out.println("ERROR"); e.printStackTrace(); } finally { chain = null; pk = null; providerBC = null; }} }

Se alguém puder ajudar agradeço desde já! Obrigado.

  • Isso é um applet ?

    rof20004   30 de set de 2015
  • Consegui encontrar o problema. Preciso aguardar um pouco antes de encerrar, pra que o provider seja removido. Com a alteração o bloco finally do método sign fica assim:

    finally { stamper.close(); os.close(); reader.close(); Security.removeProvider(provider); try { Thread.sleep(2000L); } catch (InterruptedException e) {

    e.printStackTrace(); }

    Obrigado!!!

    Jéssica Cruz   01 de out de 2015
  1. Você vai ver essas setas em qualquer página de pergunta. Com elas, você pode dizer se uma pergunta ou uma resposta foram relevantes ou não.
  2. Edite sua pergunta ou resposta caso queira alterar ou adicionar detalhes.
  3. Caso haja alguma dúvida sobre a pergunta, adicione um comentário. O espaço de respostas deve ser utilizado apenas para responder a pergunta.
  4. Se o autor da pergunta marcar uma resposta como solucionada, esta marca aparecerá.
  5. Clique aqui para mais detalhes sobre o funcionamento do GUJ!

0 resposta

Não é a resposta que estava procurando? Procure outras perguntas com as tags pdf ou faça a sua própria pergunta.