ERROR [LazyInitializer] CGLIB Enhancement failed e SSLHandshakeException [RESOLVIDO]

2 respostas
johnnylcon

Pessoal,

Estou precisando consumir um serviço web e tive de importar o seu certificado.

O problema é que estou rodando a minha aplicação em cima do java 1.5, e o certificado não funcinou, obtive a seguinte excessão:

Exception in thread main 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(Unknown Source)

at com.sun.net.ssl.internal.ssl.SSLSocketImpl.fatal(Unknown Source)

at com.sun.net.ssl.internal.ssl.Handshaker.fatalSE(Unknown Source)

at com.sun.net.ssl.internal.ssl.Handshaker.fatalSE(Unknown Source)

at com.sun.net.ssl.internal.ssl.ClientHandshaker.serverCertificate(Unknown Source)

at com.sun.net.ssl.internal.ssl.ClientHandshaker.processMessage(Unknown Source)

at com.sun.net.ssl.internal.ssl.Handshaker.processLoop(Unknown Source)

at com.sun.net.ssl.internal.ssl.Handshaker.process_record(Unknown Source)

at com.sun.net.ssl.internal.ssl.SSLSocketImpl.readRecord(Unknown Source)

at com.sun.net.ssl.internal.ssl.SSLSocketImpl.performInitialHandshake(Unknown Source)

at com.sun.net.ssl.internal.ssl.SSLSocketImpl.startHandshake(Unknown Source)

at com.sun.net.ssl.internal.ssl.SSLSocketImpl.startHandshake(Unknown Source)

at sun.net.www.protocol.https.HttpsClient.afterConnect(Unknown Source)

at sun.net.www.protocol.https.AbstractDelegateHttpsURLConnection.connect(Unknown Source)

at sun.net.www.protocol.http.HttpURLConnection.getOutputStream(Unknown Source)

at sun.net.www.protocol.https.HttpsURLConnectionImpl.getOutputStream(Unknown Source)

at Teste.main(Teste.java:48)

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(Unknown Source)

at sun.security.validator.PKIXValidator.engineValidate(Unknown Source)

at sun.security.validator.Validator.validate(Unknown Source)

at com.sun.net.ssl.internal.ssl.X509TrustManagerImpl.checkServerTrusted(Unknown Source)

at com.sun.net.ssl.internal.ssl.JsseX509TrustManager.checkServerTrusted(Unknown Source)

 13 more

Caused by: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target

at sun.security.provider.certpath.SunCertPathBuilder.engineBuild(Unknown Source)

at java.security.cert.CertPathBuilder.build(Unknown Source)

 18 more

Testei chamar o serviço a partir de uma classe de teste rodando em cima do java 1.6 e diante, e funcionou.

Sendo assim comecei um esforço para subir para o java 1.8, porém estoura a exceção abaixo:

Esse erro acontece se eu usar a versão 1.6 do java em diante.

18:00:09,083 ERROR [LazyInitializer] CGLIB Enhancement failed

net.sf.cglib.core.CodeGenerationException: java.lang.reflect.InvocationTargetException>null

at net.sf.cglib.core.AbstractClassGenerator.create(AbstractClassGenerator.java:206)

at net.sf.cglib.proxy.Enhancer.createHelper(Enhancer.java:330)

at net.sf.cglib.proxy.Enhancer.create(Enhancer.java:246)

at net.sf.cglib.proxy.Enhancer.create(Enhancer.java:406)

.

.

.

.

Caused by: java.lang.reflect.InvocationTargetException

at sun.reflect.GeneratedMethodAccessor69.invoke(Unknown Source)

at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)

at java.lang.reflect.Method.invoke(Method.java:498)

at net.sf.cglib.core.ReflectUtils.defineClass(ReflectUtils.java:373)

at net.sf.cglib.core.AbstractClassGenerator.create(AbstractClassGenerator.java:193)

 162 more

Caused by: java.lang.ClassFormatError: Illegal class name br/com/prefeituras/prp/avaliacao/app/hibernate/avaliacao/AvTerminoNotasFaltas$$EnhancerByCGLIB$$6d4ea57a-6 in class file 

at java.lang.ClassLoader.defineClass1(Native Method)

at java.lang.ClassLoader.defineClass(ClassLoader.java:763)

at java.lang.ClassLoader.defineClass(ClassLoader.java:578)

 167 more

2 Respostas

drsmachado

Como está o fonte deste arquivo? E onde você tenta injetá-lo via reflection?

johnnylcon

Consegui contornar a situação, por hora não precisarei subir a versão do java, como o produto é muito grande, precisamos de um planejamento.

Para o certificado funcionar o java 1.5, fiz o seguinte:

Fiz o import pelo keytool do java 1.8, em seguida copiei o arquivo cacerts do java 1.8 para o java 1.5 e funcionou.

att.

Criado 18 de janeiro de 2017
Ultima resposta 24 de jan. de 2017
Respostas 2
Participantes 2