JSF-PrimeFaces - Erro ao tentar injetar ajax via linha de cód.(AjaxBehavior)

2 respostas
tortoyoyo

Estou criando um componente dinâmico e preciso em um inputText ele insira um ajax com keyup, mais ele gera um erro louco e tentei milhões de formas diferentes de fazer acontecer e nada! Se alguém souber como funcionar certinho vou agradecer :D

O erro ocorre quando tente executar o ajax, ou seja somente quando eu digito algo e ele tenta executar o keyup!

Criando MethodExpression
public static MethodExpression criarMethodExspression(String valor,
			Class classe) {
		ExpressionFactory factory = FacesContext.getCurrentInstance()
				.getApplication().getExpressionFactory();
		ELContext elContext = FacesContext.getCurrentInstance().getELContext();
		return factory.createMethodExpression(elContext, valor, void.class,
				new Class<?>[] { classe });
	}
Linha do InputText e AjaxBehavior
InputText input = new InputText();
		input.setValueExpression("style",
				CControleGeral.criarValueExpression("width:100%", String.class));
		input.setValueExpression("value", CControleGeral.criarValueExpression(
				run.getBeanFiltroPesquisa(), String.class));
		
		AjaxBehavior ajaxBehavior = new AjaxBehavior();
		
		MethodExpression expression = CControleGeral.criarMethodExspression("#{bBuscaCliente.keyUpPesquisa}", ActionEvent.class);
		
		AjaxBehaviorListenerImpl ajaxBehaviorListenerImpl = new AjaxBehaviorListenerImpl(expression, expression);
		ajaxBehavior.addAjaxBehaviorListener(ajaxBehaviorListenerImpl);
		ajaxBehavior.setListener(expression);
		ajaxBehavior.setUpdate("@this");
		
		input.addClientBehavior("keyup", ajaxBehavior);
ERRO:
Mai 14, 2014 5:44:49 PM com.sun.faces.context.AjaxExceptionHandlerImpl handlePartialResponseError
Grave: java.lang.InstantiationException: br.com.smarttools.view.tabeladinamica.FiltroPadrao
	at java.lang.Class.newInstance(Unknown Source)
	at com.sun.faces.application.view.JspStateManagementStrategy.newInstance(JspStateManagementStrategy.java:187)
	at com.sun.faces.application.view.JspStateManagementStrategy.restoreTree(JspStateManagementStrategy.java:226)
	at com.sun.faces.application.view.JspStateManagementStrategy.restoreView(JspStateManagementStrategy.java:266)
	at com.sun.faces.application.StateManagerImpl.restoreView(StateManagerImpl.java:138)
	at com.sun.faces.application.view.ViewHandlingStrategy.restoreView(ViewHandlingStrategy.java:123)
	at com.sun.faces.application.view.FaceletViewHandlingStrategy.restoreView(FaceletViewHandlingStrategy.java:590)
	at com.sun.faces.application.view.MultiViewHandler.restoreView(MultiViewHandler.java:150)
	at com.sun.faces.lifecycle.RestoreViewPhase.execute(RestoreViewPhase.java:197)
	at com.sun.faces.lifecycle.Phase.doPhase(Phase.java:101)
	at com.sun.faces.lifecycle.RestoreViewPhase.doPhase(RestoreViewPhase.java:121)
	at com.sun.faces.lifecycle.LifecycleImpl.execute(LifecycleImpl.java:198)
	at javax.faces.webapp.FacesServlet.service(FacesServlet.java:646)
	at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:305)
	at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
	at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
	at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:243)
	at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
	at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:222)
	at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:123)
	at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:502)
	at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:171)
	at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:100)
	at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:953)
	at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118)
	at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:409)
	at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1044)
	at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:607)
	at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:315)
	at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
	at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
	at java.lang.Thread.run(Unknown Source)

2 Respostas

tortoyoyo

Consegui corrigir parcialmente ...

Minha classe FiltroPadrao possui um extends de PanelGrid, e passei como parâmetro no construtor um enum ... dai dava zica ... foi retirar o parâmetro passou a mudar o erro :D
Agora me surgiu outro erro .. que também não faço ideia do porque o erro é o seguinte ....

Mai 20, 2014 9:48:48 AM com.sun.faces.lifecycle.InvokeApplicationPhase execute
Advertência: 0
java.lang.ArrayIndexOutOfBoundsException: 0
	at org.apache.el.util.ReflectionUtil.getMethod(ReflectionUtil.java:190)
	at org.apache.el.parser.AstValue.invoke(AstValue.java:271)
	at org.apache.el.MethodExpressionImpl.invoke(MethodExpressionImpl.java:274)
	at org.primefaces.component.behavior.ajax.AjaxBehaviorListenerImpl.processAjaxBehavior(AjaxBehaviorListenerImpl.java:53)
	at javax.faces.event.AjaxBehaviorEvent.processListener(AjaxBehaviorEvent.java:113)
	at javax.faces.component.behavior.BehaviorBase.broadcast(BehaviorBase.java:106)
	at javax.faces.component.UIComponentBase.broadcast(UIComponentBase.java:804)
	at javax.faces.component.UIData.broadcast(UIData.java:1108)
	at javax.faces.component.UIViewRoot.broadcastEvents(UIViewRoot.java:790)
	at javax.faces.component.UIViewRoot.processApplication(UIViewRoot.java:1282)
	at com.sun.faces.lifecycle.InvokeApplicationPhase.execute(InvokeApplicationPhase.java:81)
	at com.sun.faces.lifecycle.Phase.doPhase(Phase.java:101)
	at com.sun.faces.lifecycle.LifecycleImpl.execute(LifecycleImpl.java:198)
	at javax.faces.webapp.FacesServlet.service(FacesServlet.java:646)
	at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:305)
	at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
	at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
	at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:243)
	at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
	at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:222)
	at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:123)
	at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:502)
	at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:171)
	at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:100)
	at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:953)
	at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118)
	at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:409)
	at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1044)
	at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:607)
	at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:313)
	at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
	at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
	at java.lang.Thread.run(Unknown Source)

Mai 20, 2014 9:48:48 AM com.sun.faces.context.AjaxExceptionHandlerImpl handlePartialResponseError
Grave: java.lang.ArrayIndexOutOfBoundsException: 0
	at org.apache.el.util.ReflectionUtil.getMethod(ReflectionUtil.java:190)
	at org.apache.el.parser.AstValue.invoke(AstValue.java:271)
	at org.apache.el.MethodExpressionImpl.invoke(MethodExpressionImpl.java:274)
	at org.primefaces.component.behavior.ajax.AjaxBehaviorListenerImpl.processAjaxBehavior(AjaxBehaviorListenerImpl.java:53)
	at javax.faces.event.AjaxBehaviorEvent.processListener(AjaxBehaviorEvent.java:113)
	at javax.faces.component.behavior.BehaviorBase.broadcast(BehaviorBase.java:106)
	at javax.faces.component.UIComponentBase.broadcast(UIComponentBase.java:804)
	at javax.faces.component.UIData.broadcast(UIData.java:1108)
	at javax.faces.component.UIViewRoot.broadcastEvents(UIViewRoot.java:790)
	at javax.faces.component.UIViewRoot.processApplication(UIViewRoot.java:1282)
	at com.sun.faces.lifecycle.InvokeApplicationPhase.execute(InvokeApplicationPhase.java:81)
	at com.sun.faces.lifecycle.Phase.doPhase(Phase.java:101)
	at com.sun.faces.lifecycle.LifecycleImpl.execute(LifecycleImpl.java:198)
	at javax.faces.webapp.FacesServlet.service(FacesServlet.java:646)
	at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:305)
	at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
	at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
	at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:243)
	at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
	at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:222)
	at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:123)
	at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:502)
	at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:171)
	at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:100)
	at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:953)
	at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118)
	at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:409)
	at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1044)
	at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:607)
	at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:313)
	at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
	at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
	at java.lang.Thread.run(Unknown Source)
tortoyoyo

Consegui resolver …

Nessa parte do código estava passando o parametro classe errada :S foi somente colocar a classe como vazia ela passou a funcionar <3

public static MethodExpression criarMethodExspression(String valor, Class classe) { ExpressionFactory factory = FacesContext.getCurrentInstance() .getApplication().getExpressionFactory(); ELContext elContext = FacesContext.getCurrentInstance().getELContext(); return factory.createMethodExpression(elContext, valor, void.class, new Class<?>[] { classe }); }

Criado 14 de maio de 2014
Ultima resposta 21 de mai. de 2014
Respostas 2
Participantes 1