I have a question about jsf lifecycle and back beans in JSP:
I have a button which I want to control if it was clicked once or twice. I have a flag for it in the back bean:
protected Boolean flagButtonClicked = false;
I am controlling its actions with:
public void selectAllButton_action(){
if(flagButtonClicked == false){
System.out.println("flagButtonClicked == false");
selectCB.setSelected(true);
setDisplayRerun(true);
flagButtonClicked = true;
}
else {
System.out.println("flagButtonClicked == true");
selectCB.setSelected(false);
setDisplayRerun(false);
flagButtonClicked = false;
}
}
when I click on the button I see
flagButtonClicked == false
when I click it again I again see
flagButtonClicked == false
so it never goes in the else state. Does it happen because I declare the protected Boolean flagButtonClicked = false in the back bean and whenever it is pushed it is declaring flagButtonClicked again? Or is there any other explanation?
Edit: here is the facelet:
<webuijsf:button actionExpression="#{user$reports.selectAllButton_action}" text="#{msg.report_select_all}"/>
Getter/Setter:
public Boolean getFlagButtonClicked() {
System.out.println("getFlagButtonClicked is called");
return flagButtonClicked;
}
public void setFlagButtonClicked(Boolean flagButtonClicked) {
this.flagButtonClicked = flagButtonClicked;
System.out.println("setFlagButtonClicked is clicked");
}
EDIT 2: The last version of the code is:
@ViewScoped
@ManagedBean(name="user$reports", eager=true)
public class reports extends AbstractPageBean {
protected Boolean flagButtonClicked = false;
public Boolean getFlagButtonClicked() {
System.out.println("getFlagButtonClicked is called");
return flagButtonClicked;
}
public void setFlagButtonClicked(Boolean flagButtonClicked) {
this.flagButtonClicked = flagButtonClicked;
System.out.println("setFlagButtonClicked is clicked" + flagButtonClicked );
}
public void selectAllButton_action(){
if(flagButtonClicked== Boolean.FALSE){
System.out.println("flagButtonClicked == false");
selectCB.setSelected(true);System.out.println("selectCB.setSelected(true); ");
setDisplayRerun(true);System.out.println("setDisplayRerun(true);");
setFlagButtonClicked(true);System.out.println(" setFlagButtonClicked(true);");
}
else {
System.out.println("flagButtonClicked == true");
selectCB.setSelected(false);System.out.println("selectCB.setSelected(false);");
setDisplayRerun(false);System.out.println("selectCB.setSelected(false);");
setFlagButtonClicked(false);System.out.println("setFlagButonClicked(false)");
}
}
Output is:
[#|2011-10-26T21:45:14.645+0300|INFO|glassfishv3.0|null|_ThreadID=29;_ThreadName=Thread-1;|flagButtonClicked == false|#]
[#|2011-10-26T21:45:14.646+0300|INFO|glassfishv3.0|null|_ThreadID=29;_ThreadName=Thread-1;|selectCB.setSelected(true); |#]
[#|2011-10-26T21:45:14.646+0300|INFO|glassfishv3.0|null|_ThreadID=29;_ThreadName=Thread-1;|setDisplayRerun(true);|#]
[#|2011-10-26T21:45:14.646+0300|INFO|glassfishv3.0|null|_ThreadID=29;_ThreadName=Thread-1;|setFlagButtonClicked is clicked true|#]
[#|2011-10-26T21:45:14.646+0300|INFO|glassfishv3.0|null|_ThreadID=29;_ThreadName=Thread-1;| setFlagButtonClicked(true);|#]
[#|2011-10-26T21:46:03.892+0300|INFO|glassfishv3.0|null|_ThreadID=31;_ThreadName=Thread-1;|flagButtonClicked == false|#]
[#|2011-10-26T21:46:03.892+0300|INFO|glassfishv3.0|null|_ThreadID=31;_ThreadName=Thread-1;|selectCB.setSelected(true); |#]
[#|2011-10-26T21:46:03.892+0300|INFO|glassfishv3.0|null|_ThreadID=31;_ThreadName=Thread-1;|setDisplayRerun(true);|#]
[#|2011-10-26T21:46:03.892+0300|INFO|glassfishv3.0|null|_ThreadID=31;_ThreadName=Thread-1;|setFlagButtonClicked is clicked true|#]
[#|2011-10-26T21:46:03.892+0300|INFO|glassfishv3.0|null|_ThreadID=31;_ThreadName=Thread-1;| setFlagButtonClicked(true);|#]
I tried to check bean instance:
public void init() {
super.init();
try {
_init();
} catch (Exception e) {
log("recentreports Initialization Failure", e);
throw e instanceof FacesException ? (FacesException) e: new FacesException(e);
}
FacesContext facesContex = FacesContext.getCurrentInstance();
System.out.println("facesContex.getCurrentInstance();" + facesContex.getCurrentInstance().toString() );
System.out.println("facesContex.getExternalContext().toString() " + facesContex.getExternalContext().toString());
}
and the output is:
[#|2011-10-28T11:58:03.130+0300|INFO|glassfishv3.0|null|_ThreadID=32;_ThreadName=Thread-1;|facesContex.getCurrentInstance();com.sun.faces.context.FacesContextImpl@19ea246|#]
[#|2011-10-28T11:58:03.130+0300|INFO|glassfishv3.0|null|_ThreadID=32;_ThreadName=Thread-1;|facesContex.getExternalContext().toString() com.sun.faces.context.ExternalContextImpl@1afa48b|#]
[#|2011-10-28T11:58:03.206+0300|INFO|glassfishv3.0|null|_ThreadID=32;_ThreadName=Thread-1;|flagButtonClicked == false|#]
[#|2011-10-28T11:58:03.206+0300|INFO|glassfishv3.0|null|_ThreadID=32;_ThreadName=Thread-1;|selectCB.setSelected(true); |#]
[#|2011-10-28T11:58:03.206+0300|INFO|glassfishv3.0|null|_ThreadID=32;_ThreadName=Thread-1;|setDisplayRerun(true);|#]
[#|2011-10-28T11:58:03.207+0300|INFO|glassfishv3.0|null|_ThreadID=32;_ThreadName=Thread-1;|setFlagButtonClicked is clicked true|#]
[#|2011-10-28T11:58:03.207+0300|INFO|glassfishv3.0|null|_ThreadID=32;_ThreadName=Thread-1;| setFlagButtonClicked(true);|#]
[#|2011-10-28T11:58:10.513+0300|WARNING|glassfishv3.0|org.apache.catalina.connector.Request|_ThreadID=32;_ThreadName=Thread-1;|PWC4011: Unable to set request character encoding to UTF-8 from context /lrms, because request parameters have already been read, or ServletRequest.getReader() has already been called|#]
[#|2011-10-28T11:58:10.533+0300|INFO|glassfishv3.0|null|_ThreadID=32;_ThreadName=Thread-1;|facesContex.getCurrentInstance();com.sun.faces.context.FacesContextImpl@a1b3e9|#]
[#|2011-10-28T11:58:10.533+0300|INFO|glassfishv3.0|null|_ThreadID=32;_ThreadName=Thread-1;|facesContex.getExternalContext().toString() com.sun.faces.context.ExternalContextImpl@2a92a1|#]
[#|2011-10-28T11:58:10.578+0300|INFO|glassfishv3.0|null|_ThreadID=32;_ThreadName=Thread-1;|flagButtonClicked == false|#]
[#|2011-10-28T11:58:10.579+0300|INFO|glassfishv3.0|null|_ThreadID=32;_ThreadName=Thread-1;|selectCB.setSelected(true); |#]
[#|2011-10-28T11:58:10.579+0300|INFO|glassfishv3.0|null|_ThreadID=32;_ThreadName=Thread-1;|setDisplayRerun(true);|#]
[#|2011-10-28T11:58:10.579+0300|INFO|glassfishv3.0|null|_ThreadID=32;_ThreadName=Thread-1;|setFlagButtonClicked is clicked true|#]
[#|2011-10-28T11:58:10.579+0300|INFO|glassfishv3.0|null|_ThreadID=32;_ThreadName=Thread-1;| setFlagButtonClicked(true);|#]
I am afraid this post is going to be the longest post in Stackoverflow :)