Certificado digital - Cielo

7 respostas
E

Pessoal estou tentando chamar o serviço da Cielo( Cartão debito/credito ), ja importei o certificado desta forma :

Na pasta /JRE/LIB/SECURITY coloquei o certificado da cielo
e realizei este comando para inclusão
keytool -keystore cacerts -import -alias
verisignclass3g2caAfterMay19-2009 -file cielo-hml.crt -trustcacerts

Porem mesmo assim é gerado o seguinte erro

javax.net.ssl.SSLHandshakeException: sun.security.validator.ValidatorException: PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target
	at com.sun.net.ssl.internal.ssl.Alerts.getSSLException(Alerts.java:174)
	at com.sun.net.ssl.internal.ssl.SSLSocketImpl.fatal(SSLSocketImpl.java:1591)
	at com.sun.net.ssl.internal.ssl.Handshaker.fatalSE(Handshaker.java:187)
	at com.sun.net.ssl.internal.ssl.Handshaker.fatalSE(Handshaker.java:181)
	at com.sun.net.ssl.internal.ssl.ClientHandshaker.serverCertificate(ClientHandshaker.java:1035)
	at com.sun.net.ssl.internal.ssl.ClientHandshaker.processMessage(ClientHandshaker.java:124)
	at com.sun.net.ssl.internal.ssl.Handshaker.processLoop(Handshaker.java:516)
	at com.sun.net.ssl.internal.ssl.Handshaker.process_record(Handshaker.java:454)
	at com.sun.net.ssl.internal.ssl.SSLSocketImpl.readRecord(SSLSocketImpl.java:884)
	at com.sun.net.ssl.internal.ssl.SSLSocketImpl.performInitialHandshake(SSLSocketImpl.java:1096)
	at com.sun.net.ssl.internal.ssl.SSLSocketImpl.writeRecord(SSLSocketImpl.java:623)
	at com.sun.net.ssl.internal.ssl.AppOutputStream.write(AppOutputStream.java:59)
	at java.io.BufferedOutputStream.flushBuffer(BufferedOutputStream.java:65)
	at java.io.BufferedOutputStream.flush(BufferedOutputStream.java:123)
	at org.apache.commons.httpclient.methods.EntityEnclosingMethod.writeRequestBody(EntityEnclosingMethod.java:506)
	at org.apache.commons.httpclient.HttpMethodBase.writeRequest(HttpMethodBase.java:2114)
	at org.apache.commons.httpclient.HttpMethodBase.execute(HttpMethodBase.java:1096)
	at org.apache.commons.httpclient.HttpMethodDirector.executeWithRetry(HttpMethodDirector.java:398)
	at org.apache.commons.httpclient.HttpMethodDirector.executeMethod(HttpMethodDirector.java:171)
	at org.apache.commons.httpclient.HttpClient.executeMethod(HttpClient.java:397)
	at org.apache.commons.httpclient.HttpClient.executeMethod(HttpClient.java:323)
	at com.accurate.acec.payment.gateway.CieloPagadorUtil.enviar(CieloPagadorUtil.java:228)
	at com.accurate.acec.payment.gateway.CieloPagadorUtil.createTransaction(CieloPagadorUtil.java:88)
	at com.accurate.acec.webservices.services.CieloWebServicesImpl.createTransaction(CieloWebServicesImpl.java:37)
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
	at java.lang.reflect.Method.invoke(Method.java:597)
	at weblogic.wsee.jaxws.WLSInstanceResolver$WLSInvoker.invoke(WLSInstanceResolver.java:101)
	at weblogic.wsee.jaxws.WLSInstanceResolver$WLSInvoker.invoke(WLSInstanceResolver.java:83)
	at com.sun.xml.ws.server.InvokerTube$2.invoke(InvokerTube.java:152)
	at com.sun.xml.ws.server.sei.EndpointMethodHandler.invoke(EndpointMethodHandler.java:264)
	at com.sun.xml.ws.server.sei.SEIInvokerTube.processRequest(SEIInvokerTube.java:93)
	at com.sun.xml.ws.api.pipe.Fiber.__doRun(Fiber.java:604)
	at com.sun.xml.ws.api.pipe.Fiber._doRun(Fiber.java:563)
	at com.sun.xml.ws.api.pipe.Fiber.doRun(Fiber.java:548)
	at com.sun.xml.ws.api.pipe.Fiber.runSync(Fiber.java:445)
	at com.sun.xml.ws.server.WSEndpointImpl$2.process(WSEndpointImpl.java:249)
	at com.sun.xml.ws.transport.http.HttpAdapter$HttpToolkit.handle(HttpAdapter.java:453)
	at com.sun.xml.ws.transport.http.HttpAdapter.handle(HttpAdapter.java:250)
	at com.sun.xml.ws.transport.http.servlet.ServletAdapter.handle(ServletAdapter.java:140)
	at weblogic.wsee.jaxws.HttpServletAdapter$AuthorizedInvoke.run(HttpServletAdapter.java:298)
	at weblogic.wsee.jaxws.HttpServletAdapter.post(HttpServletAdapter.java:211)
	at weblogic.wsee.jaxws.JAXWSServlet.doPost(JAXWSServlet.java:297)
	at javax.servlet.http.HttpServlet.service(HttpServlet.java:727)
	at weblogic.wsee.jaxws.JAXWSServlet.service(JAXWSServlet.java:87)
	at javax.servlet.http.HttpServlet.service(HttpServlet.java:820)
	at weblogic.servlet.internal.StubSecurityHelper$ServletServiceAction.run(StubSecurityHelper.java:227)
	at weblogic.servlet.internal.StubSecurityHelper.invokeServlet(StubSecurityHelper.java:125)
	at weblogic.servlet.internal.ServletStubImpl.execute(ServletStubImpl.java:292)
	at weblogic.servlet.internal.TailFilter.doFilter(TailFilter.java:26)
	at weblogic.servlet.internal.FilterChainImpl.doFilter(FilterChainImpl.java:56)
	at com.accurate.acec.store.StoreIdFilter.doFilter(StoreIdFilter.java:54)
	at weblogic.servlet.internal.FilterChainImpl.doFilter(FilterChainImpl.java:56)
	at weblogic.servlet.internal.WebAppServletContext$ServletInvocationAction.run(WebAppServletContext.java:3588)
	at weblogic.security.acl.internal.AuthenticatedSubject.doAs(AuthenticatedSubject.java:321)
	at weblogic.security.service.SecurityManager.runAs(SecurityManager.java:121)
	at weblogic.servlet.internal.WebAppServletContext.securedExecute(WebAppServletContext.java:2200)
	at weblogic.servlet.internal.WebAppServletContext.execute(WebAppServletContext.java:2106)
	at weblogic.servlet.internal.ServletRequestImpl.run(ServletRequestImpl.java:1428)
	at weblogic.work.ExecuteThread.execute(ExecuteThread.java:201)
	at weblogic.work.ExecuteThread.run(ExecuteThread.java:173)
Caused by: sun.security.validator.ValidatorException: PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target
	at sun.security.validator.PKIXValidator.doBuild(PKIXValidator.java:285)
	at sun.security.validator.PKIXValidator.engineValidate(PKIXValidator.java:191)
	at sun.security.validator.Validator.validate(Validator.java:218)
	at com.sun.net.ssl.internal.ssl.X509TrustManagerImpl.validate(X509TrustManagerImpl.java:126)
	at com.sun.net.ssl.internal.ssl.X509TrustManagerImpl.checkServerTrusted(X509TrustManagerImpl.java:209)
	at com.sun.net.ssl.internal.ssl.X509TrustManagerImpl.checkServerTrusted(X509TrustManagerImpl.java:249)
	at com.sun.net.ssl.internal.ssl.ClientHandshaker.serverCertificate(ClientHandshaker.java:1014)
	... 57 more
Caused by: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target
	at sun.security.provider.certpath.SunCertPathBuilder.engineBuild(SunCertPathBuilder.java:174)
	at java.security.cert.CertPathBuilder.build(CertPathBuilder.java:238)
	at sun.security.validator.PKIXValidator.doBuild(PKIXValidator.java:280)
	... 63 more

Alguem sabe o que pode ser?

Obrigado

7 Respostas

M

Tente olhar nesse tópico:

E

Ja tinha procurado no google ache um monte link, este tbm,nenhum resolveu

M

erickfm8

Poste seu código, talvez teriamos uma visualização melhor.

E

importei o certificado na jdk do weblogic e me parece que funcionou, qualquer coisa posta aqui.

Obrigado mateuscs

D

O erro:

Parece ocorrer devido o provider não estar localizando o emissor do certificado da Cielo dentro do keystore. Solicite a Cielo que envie os certificados intermediários e raiz e importe-os dentro dessa mesma Keystore para verificar se resolve o problema.

Pra importar os outros certificados é só executar o mesmo comando que usou para importar o certificado da Cielo só que usando um alias diferente pra não dar duplicidade dentro do keystore.

Espero ter ajudado.

[]s

M

erickfm8

Pu#*$, verdade kara, esqueci desse detalhe, ia comentar do import agora com você.

Boa sorte com a programação ae kara

Qualquer duvida posta ae pra gente

Coloca a solução geral no final do topico se puder
:smiley:

E

depois que coloque o certificado na jdk do weblogic funciono

Criado 11 de agosto de 2011
Ultima resposta 11 de ago. de 2011
Respostas 7
Participantes 3