Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Force JSF to process, validate and update readonly/disabled input components anyway

Tags:

validation

jsf

I am creating a calculator where a user can do the various operations by clicking on virtual numpad. Now I want to restrict the user to only select the various characters by clicking on the buttons and s/he should not be able to enter the values using keyboard. I tried using readonly="true" but it is neither validating the input nor setting the values in the bean when we click on any button.

Do we have any such restrictions available in jsf?

enter image description here

like image 734
whywake Avatar asked Sep 04 '15 04:09

whywake


1 Answers

That's the effect of JSF's safeguard against tampered/attacked requests wherein the hacker attempts to circumvent the readonly (and disabled) attribute by manipulating the HTML DOM and/or the HTTP request.

Instead of

<x:inputXxx ... readonly="true">

use

<x:inputXxx ... readonly="#{facesContext.currentPhaseId.ordinal eq 6}">

or

<x:inputXxx ... readonly="#{not facesContext.postback or facesContext.renderResponse}">

This makes sure that readonly is only effective during render response phase and not during all other JSF phases. So, when JSF is about to decode the input component during the apply request values phase, it will consider readonly="false" this way.

See also:

  • other uses of #{facesContext.currentPhaseId.ordinal}
like image 118
BalusC Avatar answered Oct 04 '22 09:10

BalusC