2010-12-15 2 views
0

Я использую поверхностные элементы 3.1.0 с JSF1.2 и Seam 2.2.0. У меня есть следующие довольно-config.xml:Шов и Prettyfaces

<url-mapping id="accountInfo"> 
    <pattern value="/account/#{accountId}/" /> 
    <view-id>/WEB-INF/view/account/account.seam</view-id> 
    <action onPostback="false">#{accountAction.loadAccountInformation}</action> 
</url-mapping> 

и Seam боб:

@Name("accountAction") 
@Scope(value = ScopeType.PAGE) 
public class AccountAction { 
@RequestParameter("accountId") 
private Long accountId; 

@Out(scope = ScopeType.PAGE) 
@In(required = false, scope = ScopeType.PAGE) 
private AccountDTO accountDto; 
} 

Mapping модель прекрасно работает, однако я всегда получаю следующее исключение:

WARNING: Cannot create Seam component, scope is not active: accountAction(PAGE) WARNING: JSF1053: (Listener: com.ocpsoft.pretty.faces.event.PrettyPhaseListener.afterPhase(), Phase ID: RESTORE_VIEW 1, View ID: /WEB-INF/view/account/account.xhtml) Exception thrown during phase-listener execution: com.ocpsoft.pretty.PrettyException: Exception occurred while processing Target Unreachable, identifier 'accountAction' resolved to null WARNING: com.ocpsoft.pretty.faces.beans.ActionExecutor.executeActions(ActionExecutor.java:68) com.ocpsoft.pretty.faces.event.PrettyPhaseListener.processEvent(PrettyPhaseListener.java:204) com.ocpsoft.pretty.faces.event.PrettyPhaseListener.afterPhase(PrettyPhaseListener.java:103) com.sun.faces.lifecycle.Phase.handleAfterPhase(Phase.java:175) com.sun.faces.lifecycle.Phase.doPhase(Phase.java:114) com.sun.faces.lifecycle.RestoreViewPhase.doPhase(RestoreViewPhase.java:102) com.sun.faces.lifecycle.LifecycleImpl.execute(LifecycleImpl.java:118) javax.faces.webapp.FacesServlet.service(FacesServlet.java:265) SEVERE: swallowing exception\ java.lang.IllegalStateException: No active conversation context at org.jboss.seam.faces.FacesMessages.instance(FacesMessages.java:352) at org.jboss.seam.jsf.SeamPhaseListener.beforeRenderResponse(SeamPhaseListener.java:484) at org.jboss.seam.jsf.SeamPhaseListener.beforeServletPhase(SeamPhaseListener.java:148) at org.jboss.seam.jsf.SeamPhaseListener.beforePhase(SeamPhaseListener.java:118) at com.sun.faces.lifecycle.Phase.handleBeforePhase(Phase.java:214) at com.sun.faces.lifecycle.Phase.doPhase(Phase.java:96) at com.sun.faces.lifecycle.LifecycleImpl.render(LifecycleImpl.java:139) at javax.faces.webapp.FacesServlet.service(FacesServlet.java:266)

Что я делаю неправильно? Thanks

ответ

2

Похоже, что что-то мешает разворачиванию текста Seam ConversationContext.

Если это невозможно решить, вы можете обойти это, вызвав свое действие на другой фазе, например RENDER_RESPONSE. Если это слишком поздно, я рекомендую использовать стиль ленивого инициализации для загрузки информации об учетной записи. (Например, используя локальное поле и нулевую проверку в методе getAccountInfo().)

+0

Спасибо за ответ, Линкольн. Да, вы правы. Я исправил это, изменив идентификатор фазы действия на RENDER_RESPONSE. – mastanik 2010-12-17 10:06:59

Смежные вопросы