Problema com conversores de Data

Pessoal, tenho o seguinte código em uma página xhtml.

<ui:define name="filtro">
		<p:focus for="txInicio"/>
		
		<h:outputText value="#{gbl.dataInicio}:"/>
		<h:outputText styleClass="required" value="*"/>
		<p:calendar id="txInicio" value="#{anoMBean.dataInicio}" 
			label="#{gbl.dataInicio}" required="true" showOn="button" 
			pattern="dd/MM/yyyy" locale="pt_BR" timeZone="America/Sao_Paulo">
			<f:convertDateTime locale="pt_BR" timeZone="America/Sao_Paulo"/>			
		</p:calendar>
		
		<p:spacer height="1" width="20"/>	
			
		<h:outputText value="#{gbl.dataFim}:"/>
		<h:outputText styleClass="required" value="*"/>
		<p:calendar id="txFim" value="#{anoMBean.dataFim}" 
			label="#{gbl.dataFim}" required="true" showOn="button"
			pattern="dd/MM/yyyy" locale="pt_BR" timeZone="America/Sao_Paulo">
			<f:convertDateTime locale="pt_BR" timeZone="America/Sao_Paulo"/>
		</p:calendar>
		
		<p:spacer height="1" width="30"/>
		<p:commandButton value="#{gbl.aplicarFiltro}" action="#{anoMBean.pesquisar}" ajax="false" 
			image="search"/>
			
</ui:define>

No anoMBean.java tenho o atributo assim:

private Date dataInicio;
private Date dataFim;

gets();
sets();

O problema é que quando eu informo uma data inválida e aplico o filtro, o converter valida a data e ao invés de exibir a mensagem de erro padrão configurada para o sistema todo, estoura um erro na tela com a mensagem e as exceções.

Em anexo está a foto da tela após a execução…

Esse é o erro que gera após tentar converter a data:

javax.faces.convert.ConverterException: Data de Fim: não foi possível reconhecer '333' como uma data.
	at javax.faces.convert.DateTimeConverter.getAsObject(DateTimeConverter.java:407)
	at org.jboss.seam.faces.component.FormValidationFieldProducer.getInputFieldValue(FormValidationFieldProducer.java:99)
	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 org.jboss.weld.util.reflection.SecureReflections$13.work(SecureReflections.java:304)
	at org.jboss.weld.util.reflection.SecureReflectionAccess.run(SecureReflectionAccess.java:54)
	at org.jboss.weld.util.reflection.SecureReflectionAccess.runAsInvocation(SecureReflectionAccess.java:163)
	at org.jboss.weld.util.reflection.SecureReflections.invoke(SecureReflections.java:298)
	at org.jboss.weld.introspector.jlr.WeldMethodImpl.invokeOnInstance(WeldMethodImpl.java:200)
	at org.jboss.weld.injection.MethodInjectionPoint.invokeOnInstance(MethodInjectionPoint.java:164)
	at org.jboss.weld.bean.ProducerMethod$1.produce(ProducerMethod.java:143)
	at org.jboss.weld.bean.AbstractProducerBean.create(AbstractProducerBean.java:360)
	at org.jboss.weld.context.DependentContext.get(DependentContext.java:62)
	at org.jboss.weld.manager.BeanManagerImpl.getReference(BeanManagerImpl.java:709)
	at org.jboss.weld.manager.BeanManagerImpl.getReference(BeanManagerImpl.java:771)
	at org.jboss.weld.manager.BeanManagerImpl.getInjectableReference(BeanManagerImpl.java:794)
	at org.jboss.weld.injection.FieldInjectionPoint.inject(FieldInjectionPoint.java:108)
	at org.jboss.weld.util.Beans.injectBoundFields(Beans.java:790)
	at org.jboss.weld.util.Beans.injectFieldsAndInitializers(Beans.java:802)
	at org.jboss.weld.manager.SimpleInjectionTarget$1.proceed(SimpleInjectionTarget.java:122)
	at org.glassfish.weld.services.InjectionServicesImpl.aroundInject(InjectionServicesImpl.java:130)
	at org.jboss.weld.injection.InjectionContextImpl.run(InjectionContextImpl.java:47)
	at org.jboss.weld.manager.SimpleInjectionTarget.inject(SimpleInjectionTarget.java:116)
	at org.jboss.seam.faces.util.BeanManagerUtils.injectNonContextualInstance(BeanManagerUtils.java:64)
	at org.jboss.seam.faces.environment.SeamApplicationWrapper.attemptExtension(SeamApplicationWrapper.java:99)
	at org.jboss.seam.faces.environment.SeamApplicationWrapper.createValidator(SeamApplicationWrapper.java:86)
	at org.jboss.seam.faces.component.UIValidateForm.validate(UIValidateForm.java:82)
	at javax.faces.component.UIInput.executeValidate(UIInput.java:1189)
	at javax.faces.component.UIInput.processValidators(UIInput.java:691)
	at javax.faces.component.UIForm.processValidators(UIForm.java:243)
	at javax.faces.component.UIComponentBase.processValidators(UIComponentBase.java:1080)
	at javax.faces.component.UIComponentBase.processValidators(UIComponentBase.java:1080)
	at javax.faces.component.UIViewRoot.processValidators(UIViewRoot.java:1180)
	at com.sun.faces.lifecycle.ProcessValidationsPhase.execute(ProcessValidationsPhase.java:76)
	at com.sun.faces.lifecycle.Phase.doPhase(Phase.java:101)
	at com.sun.faces.lifecycle.LifecycleImpl.execute(LifecycleImpl.java:118)
	at javax.faces.webapp.FacesServlet.service(FacesServlet.java:312)
	at org.apache.catalina.core.StandardWrapper.service(StandardWrapper.java:1523)
	at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:343)
	at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:215)
	at org.primefaces.webapp.filter.FileUploadFilter.doFilter(FileUploadFilter.java:79)
	at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:256)
	at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:215)
	at br.com.ocepar.autogestaogdh.framework.CharacterEncodingFilter.doFilter(CharacterEncodingFilter.java:20)
	at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:256)
	at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:215)
	at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:163)
	at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:237)
	at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:167)
	at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:256)
	at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:215)
	at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:277)
	at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:188)
	at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:641)
	at com.sun.enterprise.web.WebPipeline.invoke(WebPipeline.java:97)
	at com.sun.enterprise.web.PESessionLockingStandardPipeline.invoke(PESessionLockingStandardPipeline.java:85)
	at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:185)
	at org.apache.catalina.connector.CoyoteAdapter.doService(CoyoteAdapter.java:325)
	at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:226)
	at com.sun.enterprise.v3.services.impl.ContainerMapper.service(ContainerMapper.java:165)
	at com.sun.grizzly.http.ProcessorTask.invokeAdapter(ProcessorTask.java:791)
	at com.sun.grizzly.http.ProcessorTask.doProcess(ProcessorTask.java:693)
	at com.sun.grizzly.http.ProcessorTask.process(ProcessorTask.java:954)
	at com.sun.grizzly.http.DefaultProtocolFilter.execute(DefaultProtocolFilter.java:170)
	at com.sun.grizzly.DefaultProtocolChain.executeProtocolFilter(DefaultProtocolChain.java:135)
	at com.sun.grizzly.DefaultProtocolChain.execute(DefaultProtocolChain.java:102)
	at com.sun.grizzly.DefaultProtocolChain.execute(DefaultProtocolChain.java:88)
	at com.sun.grizzly.http.HttpProtocolChain.execute(HttpProtocolChain.java:76)
	at com.sun.grizzly.ProtocolChainContextTask.doCall(ProtocolChainContextTask.java:53)
	at com.sun.grizzly.SelectionKeyContextTask.call(SelectionKeyContextTask.java:57)
	at com.sun.grizzly.ContextTask.run(ContextTask.java:69)
	at com.sun.grizzly.util.AbstractThreadPool$Worker.doWork(AbstractThreadPool.java:330)
	at com.sun.grizzly.util.AbstractThreadPool$Worker.run(AbstractThreadPool.java:309)
	at java.lang.Thread.run(Thread.java:662)
Caused by: java.text.ParseException: Unparseable date: "333"
	at java.text.DateFormat.parse(DateFormat.java:337)
	at javax.faces.convert.DateTimeConverter.getAsObject(DateTimeConverter.java:404)
	... 75 more

Se alguém tiver uma ideia do porque que isso está acontecendo eu ficaria muito grata.


faça o seguinte, como o componente do primefaces é um pick-component, coloque o maxlenght do seu componente calendar como 0, assim não será possível adicionar qualquer dado do teclado.

Aí é que está o problema, porque o cliente quer ter a possibilidade de digitar a data ou escolher no calendário.
Eu tenho mesmo é que fazer a validação.

E o que me deixa mais encabulada é que nas telas de cadastro onde tenho o mesmo componente calendar com o conversor, o sistema faz a validação corretamente, mas nas telas onde tenho filtro por intervalo de datas gera essa exceção…

olha, você tem 3 opções então.

    • Utilizar o inputMask, que assim a pessoa terá orbigatoriamente que escrever e não terá direito a escolha de data.
    • Vetar o calendar com a primeira opção como foi dito

Acredito que esse última solução citado seria meio inviável.
Mas apesar disso, consegui descrobrir aonde estava o problema.

Tenho um validador na tela dessa forma:

<s:validateForm validatorId="periodoValidator" fields="inicio=txInicio fim=txFim"/>

Tirei esse validador e funcionou da forma que eu precisava.