У меня странная ситуация, когда i: f: convertNumber не работает при попытке сохранить его на нетипизированной карте.
Я ожидаю, что число будет храниться как объект java.lang.Double на карте..
Вот выдержка из xhtml:
<h:inputText value="#{tInputBean.generalMap['myNumber']}" id="testNumber">
<f:convertNumber />
</h:inputText>
<p:message for="testNumber" />
И вот боб:
@Named("tInputBean")
@Scope("view")
public class TInputBean {
private Log log = LogFactory.getLog(TInputBean.class);
private Map generalMap = new HashMap();
// .. and the setter getter
....
}
А вот мой журнал:
DEBUG PhaseTracker - BEFORE PHASE RESTORE_VIEW 1
DEBUG PhaseTracker - AFTER PHASE RESTORE_VIEW 1
DEBUG PhaseTracker - BEFORE PHASE APPLY_REQUEST_VALUES 2
DEBUG DebugUtil - ============== start debugMap parameter map : ==============
DEBUG DebugUtil - testNumber='123123123'
DEBUG DebugUtil - javax.faces.partial.execute='SaveHeader testNumberPanel RPBPanel'
DEBUG DebugUtil - SaveHeader='SaveHeader'
DEBUG DebugUtil - javax.faces.partial.render='messages RPBPanel DebugVersionHeader testNumberPanel'
DEBUG DebugUtil - javax.faces.source='SaveHeader'
DEBUG DebugUtil - j_idt42='j_idt42'
DEBUG DebugUtil - javax.faces.ViewState='7088371747667351331:-3641627426454744246'
DEBUG DebugUtil - transNum='TRX003'
DEBUG DebugUtil - javax.faces.partial.ajax='true'
DEBUG DebugUtil - ============== end debugMap parameter map : ==============
DEBUG PhaseTracker - AFTER PHASE APPLY_REQUEST_VALUES 2
DEBUG PhaseTracker - BEFORE PHASE PROCESS_VALIDATIONS 3
DEBUG PhaseTracker - AFTER PHASE PROCESS_VALIDATIONS 3
DEBUG PhaseTracker - BEFORE PHASE RENDER_RESPONSE 6
DEBUG PhaseTracker - AFTER PHASE RENDER_RESPONSE 6
И после рендеринга <p:message for="testNumber" />
заменяется на: {0}: Conversion error occurred.
Вещи, которые я замечаю:
- Во время ошибки преобразования исключение не происходит.Мой обработчик исключений не обрабатывает ничего, что фиксирует и регистрирует все исключения.Нет трассировки исключений.
- Я не могу указать тип, такой как java.lang. Двойной в теге
<f:convertNumber>
.
Должен ли я сделать свой собственный конвертер, чтобы это работало?Я уже представляю себе такие вещи, как:
<h:inputText value="#{tInputBean.generalMap['myNumber']}" id="testNumber">
<f:converter type="MyDoubleConverter" />
</h:inputText>
<p:message for="testNumber" />
Пожалуйста, поделитесь своим мнением по этому вопросу.Спасибо!
ОБНОВЛЕНИЕ
Я создал простой конвертер, который соответствует моим потребностям, и пока он работает нормально.Вот код, пожалуйста, поделитесь своим мнением по этому поводу:
@FacesConverter(value="Double")
public class DoubleConverter implements Converter {
private Log log = LogFactory.getLog(DoubleConverter.class);
@Override
public String getAsString(FacesContext context, UIComponent component, Object value) {
//log.debug("locale : " + context.getViewRoot().getLocale());
DecimalFormat format = (DecimalFormat) DecimalFormat.getInstance(context.getViewRoot().getLocale());
//log.debug("VALUE == " + value);
String result = value == null || value.toString().trim().length() == 0 ? null : format.format(value);
//log.debug("RESULT == " + value);
return result;
}
@Override
public Object getAsObject(FacesContext context, UIComponent component, String value) {
//log.debug("locale : " + context.getViewRoot().getLocale());
//log.debug("STRING VALUE == " + value);
DecimalFormat format = (DecimalFormat) DecimalFormat.getInstance(context.getViewRoot().getLocale());
try {
Object result = ((value == null) || (value.trim().length() == 0)) ? null : format.parse(value).doubleValue();
//log.debug("RESULT == " + result);
return result;
} catch (Exception e) {
log.error(e,e);
throw new ConverterException(e);
}
}
}
А вот как мой jsf использует его:
<h:inputText value="#{tInputBean.generalMap['myNumber']}"
id="testNumber" converter="Double"/>
<p:message for="testNumber" />