0

这类似于关于字符集验证的问题,除了一些字符(例如“żźć”)在提交后显示为 HTML 实体(“żźć”)。奇怪的是像“&”这样的东西保存为“&”。

我已经在 Tomcat 端尝试过 Spring 的 CharacterEncodingFilter 和 Connector,但这似乎根本没有帮助。数据库编码似乎不是问题,因为我的表单在与 AJAX 请求和会话 bean 一起使用时工作正常(与正常的提交和请求范围相反)。

这是我的表格的一部分:

<?xml version='1.0' encoding='UTF-8' ?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml"
      xmlns:h="http://java.sun.com/jsf/html"
      xmlns:f="http://java.sun.com/jsf/core"
      xmlns:p="http://primefaces.org/ui"
      xmlns:ui="http://java.sun.com/jsf/facelets"
      >
  <h:body>
   <ui:composition template="/tpls/main-layout.xhtml">
   <ui:define name="content">
    <h:form>
    ...
     <p:commandButton value="#{i18n.msg('_Save')}"
      action="view" actionListener="#{readerController.save}" ajax="false" />
    ...
     <p:panelGrid>
      <p:row>
       <p:column><h:outputLabel for="lastName" value="#{i18n.msg('Reader.lastName')}" /></p:column>
       <p:column><p:inputText id="lastName" value="#{readerController.currentReader.lastName}" required="true">
        <p:ajax update="msg-lastName" event="change" />
        <f:validateRegex pattern="#{applicationConfiguration.nameValidationPattern}" />
        <f:validateLength maximum="50" />
       </p:inputText></p:column>
       <p:column><p:message for="lastName" id="msg-lastName" /></p:column>
      </p:row>
      ...
     </p:panelGrid>
    </h:form>
  </ui:define>
  </ui:composition>
</h:body>
</html>

编辑:作为一个澄清 - 你可以#{i18n.msg('_Save')}Save和替换之类的东西#{applicationConfiguration.nameValidationPattern},例如[^0-9]

4

1 回答 1

0

完全魔术。

我正在使用它进入我的编辑视图:

<p:commandButton action="#{readerController.edit(list.id)}" title="#{i18n.msg('_Edit')}" icon="ui-icon-gear" />

这要提交:

<p:commandButton ajax="false" value="#{i18n.msg('_Save')}" action="view" actionListener="#{readerController.save}" />

并且编码无法正常工作。

使用它去编辑视图:

<p:commandButton ajax="false" action="#{readerController.edit(list.id)}" title="#{i18n.msg('_Edit')}" icon="ui-icon-gear" />

同样提交和编码工作正常......更准确地说,在两端使用 ajax="false" 或 ajax="true" 工作。

去搞清楚。

编辑:实际上是上述内容和来自Corrupted characters的CharacterEncodingFilter在提交表单后重新显示在输入中。

于 2012-07-17T17:04:40.280 回答