Sto utilizzando jsf-ri 2.0.3 dove è necessario il supporto per l'ebraico e il russo. Il problema è che vedo dei messaggi senza senso sullo schermo invece del testo corretto.i18n con file di proprietà codificati UTF-8 nell'applicazione JSF 2.0
Prima di tutto ho definito pacchetti (* _locale.properties) per ogni lingua. I file sono nella codifica UTF-8. locali secondo luogo, ho definito il difetto e supportato in faces-config.xml
<locale-config>
<default-locale>iw</default-locale>
<supported-locale>en</supported-locale>
<supported-locale>ru</supported-locale>
</locale-config>
Che Ho aggiunto un filtro personalizzato che imposterà la codifica risposta charcter UTF-8.
<filter>
<filter-name>encodingFilter</filter-name>
<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
<init-param>
<param-name>forceEncoding</param-name>
<param-value>true</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>encodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
E infine quando creo un semplice xhtml per eseguire il debug l'uscita Vedo molto strani risultati
<f:loadBundle basename="i18n.frontend.homepage" var="msg"/>
<strong>i18n: </strong><h:outputText value="#{msg.language}"/>
<br/>
<strong>Locale: </strong>
<h:outputText value="#{facesContext.externalContext.response.locale}"/>
<br/>
<strong>Encoding: </strong>
<h:outputText value="#{facesContext.externalContext.response.characterEncoding}"/>
Il risultato è:
i18n: ×¢×ר×ת
Locale: en_US
Encoding: UTF-8
Cosa c'è di sbagliato con la mia configurazione?
Questo è un grande strumento. Sarà aggiunto a OmniFaces un giorno? – Med
@Med: ho preso in considerazione questo, ma ho deciso che questo è al limite con "Hacky". Piuttosto, usa gli editor corretti e crea strumenti come Eclipse e/o Maven/Ant. Ad esempio, quando si utilizza l'editor di file di proprietà built-in di Eclipse, UTF-8 verrà salvato in modo trasparente come ISO-8859-1 con codepoint unicode dove necessario. – BalusC
Ok, ho capito il tuo punto! Grazie. – Med