Questions tagged [jsf]

JSF, Jakarta Server Faces (formerly known as JavaServer Faces) is a model-view-presenter framework typically used to create HTML form based web applications. Using the standard components and render kit, stateful HTML views can be defined using Facelets or JSP tags and wired to model data and application logic via backing beans.

Information to provide when asking JSF questions

If you want good answers to your JSF questions, you will get it more quickly if you immediately include the following information in the question.

  • Which JSF implementation and version are you using?

    Mojarra or MyFaces? 1.0.x, 1.1.x, 1.2.x, 2.0.x, 2.1.x, 2.2.x, 2.3.x, 3.0.x or 4.0.x? You can usually find the exact implementation name and version in webapp's startup log or at least in JAR's filename, and/or MANIFEST.MF file. Also mention the exact version of any JSF component/utility library involved in the problem. If you don't mention anything, we will assume the latest version available to date.

    The difference between JSF 1.x and JSF 2.x/3.x/4.x is too big to be able to give a reliable answer which can cover both versions. Also, each of the JSF implementations/libraries may have its own set of version-specific bugs/quirks so that the answerer can, if necessary, take this into account. In case there is a newer version available, you should try upgrading and then re-test the problem.

  • Any warnings/errors/exceptions in faces messages, or browser console, or server logs?

    If the application appears to be failing silently, make sure that you've added a <h:messages> tag to your JSF page to avoid that you miss any faces messages. Also, make sure that you've set javax.faces.PROJECT_STAGE to Development in web.xml to avoid that you miss any development warnings/hints. Also, make sure that you have read the browser console (press F12 in Chrome/Firefox23+/IE9+) and server logs from top to bottom. Investigate any line which represents a warning or error or looks otherwise abnormal.

    When you get an exception, then always include the bottommost root cause of the stack trace along with all "at" lines (all other causes there above are just consequences). Exceptions are generally excellent search keywords. You can just search on the exception type+message and optionally the 1st "at" line of the trace without the parentheses+linenumber to see if it isn't already asked and answered before. Example 1, example 2, example 3.

  • Provide a minimal reproducible example!

    Try to isolate the problem as much as possible into the smallest possible but complete copy'n'paste'n'runnable example. As to Java (backing bean) code, you do not need to include imports and getters/setters. You also do not need to include any fields and methods which do not contribute to the actual problem. As to XHTML (view) code, you do not need to include any tags and attributes which do not contribute to the actual problem. You also do not need to include the whole business service layer (EJB/JPA/Spring/DAO/JDBC/etc), just a hardcoded model is sufficient (otherwise it's not necessarily a JSF related problem).

    You should assume that the potential answerer will copypaste the provided Java code into an empty test class and auto-organize imports and autogenerate getters/setters if necessary, and copypaste the provided XHTML code into a <h:body> of a templateless(!) test file in a blank project with everything set to default (i.e. no or empty XML configuration files!) and using currently latest versions of libraries/server, unless explicitly otherwise mentioned in the question itself (and you should also test it yourself this way beforehand!).

Without the above information and/or a proper MCVE, getting answers will depend more on luck (there's no ambiguity nor noise in the question as to possible causes) and educated guesses of the potential answerers (knowing the most common starter's mistakes). You may otherwise risk the question being closed as "Off-Topic, because there's no MCVE or there's only a full code dump", or "Too Broad, because it basically asks us to write code instead of to explain and solve a problem".


Minimum requirements

  • Faces 4.0 requires a minimum of Java 11, Servlet 6.0, EL 5.0 and CDI 4.0. Faces 4.0 is part of Jakarta EE 10.
  • JSF 3.0 requires a minimum of Java 1.8, Servlet 5.0, EL 4.0 and CDI 3.0. JSF 3.0 is part of Jakarta EE 9.
  • JSF 2.4 does actually not really exist even though this is accidentally present in Maven! See also Upgrading to JSF 2.4 and Do not use org.glassfish Mojarra 2.4.0! You need to pick the currently latest 2.3.x, or JSF 3.x or newer.
  • JSF 2.3 requires a minimum of Java 1.8, Servlet 3.0, EL 3.0 and CDI 1.2. Servlet 4.0 is optional and will enable JSF 2.3 to serve resources via HTTP/2 push. When <f:websocket> is used, JSONP 1.1 is required as well. CDI 1.2 is explicitly required because of the @ManagedBean being deprecated. JSF 2.3 is part of Java EE 8 / Jakarta EE 8.
  • JSF 2.2 requires a minimum of Java 1.6, Servlet 3.0 and EL 2.2. Servlet 3.0 is explicitly required because of the new file upload component which is internally using the standard Servlet 3.0 API without the need for 3rd party libraries. JSF 2.2 is part of Java EE 7.
  • JSF 2.1 requires a minimum of Java 1.5, Servlet 2.5 and EL 2.1. Servlet 3.0 is optional and will enable JSF 2.1 to automatically run on *.jsf without any necessary web.xml configuration as long as there's a faces-config.xml.
  • JSF 2.0 requires a minimum of Java 1.5, Servlet 2.5 and EL 2.1. You can use Servlet 2.4 if you supply your own EL 2.1 API/impl. JSF 2.0 is part of Java EE 6.
  • JSF 1.2 requires a minimum of Java 1.5, Servlet 2.5, JSP 2.1 and EL 2.1. If you replace JSP 2.1 by Facelets 1.x as default view technology, then you can use JSF 1.2 on Servlet 2.4. JSF 1.2 is part of Java EE 5.
  • JSF 1.0 and 1.1 requires a minimum of Java 1.4, Servlet 2.4 and JSP 2.0. JSF 1.0 is part of J2EE 1.4.

Examples of Java EE and Servlet containers

  • Servlet 6.0: Tomcat 10.1.x, GlassFish 7.x, WildFly 27.x.x
  • Servlet 5.0: Tomcat 10.0.x, GlassFish 6.x, Open Liberty 21.x.x.x, WildFly 23.x.x
  • Servlet 4.0: Tomcat 9.x, GlassFish/Payara 5.x
  • Servlet 3.1: Tomcat 8.x, WildFly 8/9/10/11.x, GlassFish/Payara 4.x, TomEE 7.x, WebSphere 9.x
  • Servlet 3.0: Tomcat 7.x, JBoss AS 6/7.x, GlassFish 3.x, TomEE 1.x, WebSphere 8.x
  • Servlet 2.5: Tomcat 6.x, JBoss AS 5.x, GlassFish 2.x, WebSphere 7.x
  • Servlet 2.4: Tomcat 5.5.x, JBoss AS 4.x, Sun Java Application Server, WebSphere 5/6.x

Installing JSF

Depending on the server used, JSF may already be built-in (full fledged Java EE containers such as WildFly, JBoss EAP, TomEE, Payara, GlassFish, WebSphere, etc.), or not (barebones JSP/Servlet containers such as Tomcat, Jetty, etc.). If the server doesn't ship with JSF built-in, then you need to manually install a JSF implementation to your choice (Mojarra or MyFaces). Don't forget JSTL, those barebones JSP/Servlet containers usually also don't even ship with JSTL.


Resources

Online tutorials

Offline tutorials ("books")

JSF implementations

  • Mojarra - Oracle's reference implementation (RI), standard part of e.g. WildFly
  • MyFaces - Apache's alternative, standard part of e.g. TomEE

JSF component/utility libraries

Frequently asked questions

More links:

Related tags

35737 questions
880
votes
16 answers

What is the difference between JSF, Servlet and JSP?

I have some questions. These are : How are JSP and Servlet related to each other? Is JSP some kind of Servlet? How are JSP and JSF related to each other? Is JSF some kind of Pre-Build UI based JSP like ASP.NET-MVC?
Cheung
  • 15,293
  • 19
  • 63
  • 93
411
votes
4 answers

Differences between action and actionListener

What is the difference between action and actionListener, and when should I use action versus actionListener?
Murat Güzel
  • 4,986
  • 4
  • 19
  • 12
408
votes
2 answers

How to choose the right bean scope?

I noticed that there are different bean scopes like: @RequestScoped @ViewScoped @FlowScoped @SessionScoped @ApplicationScoped What is the purpose of each? How do I choose a proper scope for my bean?
Valter Silva
  • 16,446
  • 52
  • 137
  • 218
367
votes
13 answers

commandButton/commandLink/ajax action/listener method not invoked or input value not set/updated

Sometimes, when using , or , the action, actionListener or listener method associated with the tag are simply not being invoked. Or, the bean properties are not updated with submitted UIInput values. What are…
Muhammad Hewedy
  • 29,102
  • 44
  • 127
  • 219
270
votes
9 answers

Why JSF calls getters multiple times

Let's say I specify an outputText component like this: If I print a log message when the getter for someProperty is called and load the page, it is trivial to notice that the getter is being…
Sevas
  • 4,215
  • 3
  • 27
  • 26
239
votes
1 answer

What is the JSF resource library for and how should it be used?

The JSF , and components have a library attribute. What is this and how should this be used? There are a lot of examples on the web which use it as follows with the common content/file type css,…
BalusC
  • 1,082,665
  • 372
  • 3,610
  • 3,555
236
votes
13 answers

What are the main disadvantages of Java Server Faces 2.0?

Yesterday I saw a presentation on Java Server Faces 2.0 which looked truly impressive, even though I am currently a happy ASP.NET MVC / jQuery developer. What I liked most about JSF was the huge amount of AJAX-Enabled UI components which seem to…
Adrian Grigore
  • 33,034
  • 36
  • 130
  • 210
235
votes
2 answers

How to include another XHTML in XHTML using JSF 2.0 Facelets?

What is the most correct way to include another XHTML page in an XHTML page? I have been trying different ways, none of them are working.
Ikthiander
  • 3,917
  • 8
  • 37
  • 54
219
votes
5 answers

Understanding PrimeFaces process/update and JSF f:ajax execute/render attributes

What exactly are process and update in PrimeFaces p:commandXxx components and execute and render in f:ajax tag? Which works at the time of validation? What does update attribute do rather than updating value to component from back end? Do process…
Shardendu
  • 3,480
  • 5
  • 20
  • 28
184
votes
11 answers

javax.faces.application.ViewExpiredException: View could not be restored

I have written simple application with container-managed security. The problem is when I log in and open another page on which I logout, then I come back to first page and I click on any link etc or refresh page I get this exception. I guess it's…
l245c4l
  • 4,135
  • 9
  • 35
  • 40
176
votes
3 answers

JSTL in JSF2 Facelets... makes sense?

I would like to output a bit of Facelets code conditionally. For that purpose, the JSTL tags seem to work fine: ... However, I'm not sure if this is a best practice? Is there another way to achieve my goal?
Jan
  • 9,397
  • 13
  • 47
  • 52
160
votes
4 answers

Performing user authentication in Java EE / JSF using j_security_check

I'm wondering what the current approach is regarding user authentication for a web application making use of JSF 2.0 (and if any components do exist) and Java EE 6 core mechanisms (login/check permissions/logouts) with user information hold in a JPA…
ngeek
  • 7,733
  • 11
  • 36
  • 42
160
votes
8 answers

Handling a colon in an element ID in a CSS selector

JSF is setting the ID of an input field to search_form:expression. I need to specify some styling on that element, but that colon looks like the beginning of a pseudo-element to the browser so it gets marked invalid and ignored. Is there anyway to…
sblundy
  • 60,628
  • 22
  • 121
  • 123
157
votes
2 answers

What can , and be used for?

Can anyone clarify how we can use in general, or a in real world example, this snippet?
Hanynowsky
  • 2,970
  • 5
  • 32
  • 43
156
votes
6 answers

How to find out client ID of component for ajax update/render? Cannot find component with expression "foo" referenced from "bar"

The following code is inspired from PrimeFaces DataGrid + DataTable Tutorials and put into a of a residing in a of a . Here is the inner part of the code (starting from p:tab component); the outer part is…
perissf
  • 15,979
  • 14
  • 80
  • 117
1
2 3
99 100