2012-12-26 1 views
3

JSF 2.0 및 Primefaces 3.4.2를 사용 중이며, 지연 성 부하를 사용하여 데이터 테이블을 채 웁니다.프라임 그래프 선택 가능한 행이 뷰 스코프를 사용하여 작동하지 않습니다.

managedbean의 범위를 볼 때 selectedRow 데이터 테이블은 널 포인터 예외를 제공합니다. 세션 범위를 사용하면 managedbean에서 selectedRow를 얻을 수 있습니다.

범위를 지정하는 데 CDI Spring 주석을 사용하고 있습니다. 뷰 범위를 만들려면 this 메서드를 사용했습니다.

내가 두 번째 페이지에 페이지를 매기는 경우 뷰 범위를 사용하는 다른 일을 발견하고 나는이 selectedRow를 얻을 수, 첫 페이지로 회복 한 1

업데이트. 페이지 매김없이 행을 선택하면 널 포인터 예외가 발생합니다.

JSF 페이지

<p:dataTable id="dataTable" var="req" lazy="true" value="#{emp.lazyModel}" 
       paginator="true" rows="10" 
          selection="#{emp.selectedRequest}" 
          selectionMode="single">       
      <p:ajax event="rowSelect" listener="#{emp.onRowSelect}" /> 

ManagedBean은

@Named("emp") 
@Scope("view") 
public class EmployeesManagedBean implements Serializable { 

    @PostConstruct 
    public void init() { 
     initTable(); 
    } 

    private void initTable() { 
     lazyModel = new LazyRequestDataModel(requestList, requestService); 
    } 

    public LazyDataModel<Employee> getLazyModel() { 
     return lazyModel; 

    } 

나는 onRowSelect 방법이 라인에서 nullpointer 예외를 얻고있다

Emp emp = (Emp) event.getObject()); 
System.out.println(emp.getEmpNo()); 

전체 오류 스택 트레이스

java.lang.NullPointerException 
    at net.test.managed.bean.RequestManagedBean.onRowSelect(RequestManagedBean.java:134) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
    at java.lang.reflect.Method.invoke(Method.java:601) 
    at com.sun.el.parser.AstValue.invoke(AstValue.java:187) 
    at com.sun.el.MethodExpressionImpl.invoke(MethodExpressionImpl.java:297) 
    at org.primefaces.component.behavior.ajax.AjaxBehaviorListenerImpl.processAjaxBehavior(AjaxBehaviorListenerImpl.java:52) 
    at org.primefaces.event.SelectEvent.processListener(SelectEvent.java:40) 
    at javax.faces.component.behavior.BehaviorBase.broadcast(BehaviorBase.java:106) 
    at javax.faces.component.UIComponentBase.broadcast(UIComponentBase.java:760) 
    at javax.faces.component.UIData.broadcast(UIData.java:1071) 
    at javax.faces.component.UIData.broadcast(UIData.java:1093) 
    at javax.faces.component.UIViewRoot.broadcastEvents(UIViewRoot.java:794) 
    at javax.faces.component.UIViewRoot.processApplication(UIViewRoot.java:1259) 
    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:118) 
    at javax.faces.webapp.FacesServlet.service(FacesServlet.java:593) 
    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:301) 
    at weblogic.servlet.internal.TailFilter.doFilter(TailFilter.java:26) 
    at weblogic.servlet.internal.FilterChainImpl.doFilter(FilterChainImpl.java:56) 
    at weblogic.servlet.internal.RequestEventsFilter.doFilter(RequestEventsFilter.java:27) 
    at weblogic.servlet.internal.FilterChainImpl.doFilter(FilterChainImpl.java:56) 
    at weblogic.servlet.internal.WebAppServletContext$ServletInvocationAction.wrapRun(WebAppServletContext.java:3730) 
    at weblogic.servlet.internal.WebAppServletContext$ServletInvocationAction.run(WebAppServletContext.java:3696) 
    at weblogic.security.acl.internal.AuthenticatedSubject.doAs(AuthenticatedSubject.java:321) 
    at weblogic.security.service.SecurityManager.runAs(SecurityManager.java:120) 
    at weblogic.servlet.internal.WebAppServletContext.securedExecute(WebAppServletContext.java:2273) 
    at weblogic.servlet.internal.WebAppServletContext.execute(WebAppServletContext.java:2179) 
    at weblogic.servlet.internal.ServletRequestImpl.run(ServletRequestImpl.java:1490) 
    at weblogic.work.ExecuteThread.execute(ExecuteThread.java:256) 
    at weblogic.work.ExecuteThread.run(ExecuteThread.java:221) 

답변

3

나는 CDI에서 지원되는 @ViewAccessScoped을 사용하여이 문제를 해결할 수있었습니다. 의존성을 maven에 추가하거나 http://myfaces.apache.org/extensions/cdi/download.html에서 직접 다운로드하여 classpath에 넣으십시오.

<dependency> 
    <groupId>org.apache.myfaces.extensions.cdi.core</groupId> 
    <artifactId>myfaces-extcdi-core-api</artifactId> 
    <version>1.0.5</version> 
    <scope>compile</scope> 
</dependency> 

하나의 작은 문제가 계속 응용 프로그램을 처음 배포 할 때, 나는 아직도 내가 행 값을 선택받을 수 있어요 이후의 선택에 대해 행 값으로 선택되지 않습니다 즉 남아있다. 내가 rowKey를 추가 할 경우

+0

그 문제를 계속 조사해야합니다. 결국 처음부터 제대로 작동하지 않을 것입니다. – Daniel

+0

@ 대니얼 처음으로 선택한 행을 얻지 못하는 것에 대한 단서가 없습니다. – user75ponic

+0

당신이 그 대답을 얻지 못한다면 프라임 폼에 대해 물어보십시오 ... – Daniel

1

선택 항목을 사용하려면 datatable에 rowKey 특성을 제공해야한다고 생각합니다.

+1

다음 내가 얻을 org.primefaces.component.datatable.DataTable.getRowData (DataTable.java:798)에서 예외 'java.lang.NullPointerException이 \t org.primefaces.component.datatable.feature에서 \t .SelectionFeature.decodeSingleSelection (SelectionFeature.java:46)'PF 3.4.2에 대한 확실하지 않은 rowKey가 필요합니다. [this] (http://www.primefaces.org/showcase-labs/ui/datatableComplex.jsf). – user75ponic

+1

이 예제에는 rowKey가 있습니다. 예를 들어 지연로드로 생각했습니다. 이 예제에는 rowKey 태그가 없지만 LazyDataModel 구현에 넣습니다. 그들은 getRowKey와 getRowData 메소드를 작성했습니다. 나는 이에 관한 이론을 가지고있다 : 페이지에 c : 태그가 있거나 바인딩 속성이있다. 전체 xhtml 코드를 제공하면 도움이 될 것입니다. Session scope bean으로 모든 것이 잘 작동한다고 말했기 때문에 이것이 문제라고 생각합니다. – partlov