无法在MessageSource中找到消息

我试图让一个简单的spring应用程序运行,但得到以下exception:

javax.servlet.ServletException:javax.servlet.jsp.JspTagException:在代码’label.firstname’下找不到区域设置’en_US’的消息。

我的contact.jsp文件:

      Spring 3 MVC Series - Contact Manager | viralpatel.net   

Contact Manager

<input type="submit" value=""/>

Contacts

Name Email Telephone  
${contact.lastname}, ${contact.firstname} ${contact.email} ${contact.telephone} delete

我的spring-servlet.xml文件

               <!--        classpath:hibernate.cfg.xml   org.hibernate.cfg.AnnotationConfiguration    ${jdbc.dialect} true         

我正在打url:

本地主机:8080 / MavenWeb-0.0.1 /索引

和我的服务器堆栈跟踪:

 SEVERE: No message found under code 'label.firstname' for locale 'en_US'. javax.servlet.jsp.JspTagException: No message found under code 'label.firstname' for locale 'en_US'. at org.springframework.web.servlet.tags.MessageTag.doStartTagInternal(MessageTag.java:184) at org.springframework.web.servlet.tags.RequestContextAwareTag.doStartTag(RequestContextAwareTag.java:79) at org.apache.jsp.WEB_002dINF.jsp.contact_jsp._jspx_meth_spring_005fmessage_005f0(contact_jsp.java:252) at org.apache.jsp.WEB_002dINF.jsp.contact_jsp._jspx_meth_form_005flabel_005f0(contact_jsp.java:219) at org.apache.jsp.WEB_002dINF.jsp.contact_jsp._jspx_meth_form_005fform_005f0(contact_jsp.java:138) at org.apache.jsp.WEB_002dINF.jsp.contact_jsp._jspService(contact_jsp.java:91) at org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70) at javax.servlet.http.HttpServlet.service(HttpServlet.java:722) at org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:419) at org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:389) at org.apache.jasper.servlet.JspServlet.service(JspServlet.java:333) at javax.servlet.http.HttpServlet.service(HttpServlet.java:722) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:304) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) at org.apache.catalina.core.ApplicationDispatcher.invoke(ApplicationDispatcher.java:684) at org.apache.catalina.core.ApplicationDispatcher.processRequest(ApplicationDispatcher.java:471) at org.apache.catalina.core.ApplicationDispatcher.doForward(ApplicationDispatcher.java:402) at org.apache.catalina.core.ApplicationDispatcher.forward(ApplicationDispatcher.java:329) at org.springframework.web.servlet.view.InternalResourceView.renderMergedOutputModel(InternalResourceView.java:238) at org.springframework.web.servlet.view.AbstractView.render(AbstractView.java:250) at org.springframework.web.servlet.DispatcherServlet.render(DispatcherServlet.java:1047) at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:817) at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:719) at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:644) at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:549) at javax.servlet.http.HttpServlet.service(HttpServlet.java:621) at javax.servlet.http.HttpServlet.service(HttpServlet.java:722) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:304) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:240) at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:164) at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:462) at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:164) at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:100) at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:563) at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118) at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:403) at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:301) at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:162) at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:309) at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886) at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908) at java.lang.Thread.run(Thread.java:662) 

解决问题的步骤:

  1. 仅将messages_en.properties文件放在src / main / resource文件夹中
  2. 确保文件名正确为messages_en.properties而不是message_en.properties
  3. 使用mvn clean install进行maven构建时,messages_en.properties文件将出现在target / projectname / WEB-INF / classes / messages.properties中
  4. 检入spring-servlet.xml(名称可能不同)并使用classpath:messages作为messageSource中的basename

它应该工作,因为它解决了我的问题。

     

您的MessageSource bean定义有点令人困惑。 通常,basename是要用于消息解析的文件名的前缀(减去.properties),Spring和JDK ResourceBundle类将附加语言和/或国家/地区缩写。

     

例如,如果您打算使用messages.propertiesmessages_es.propertiesmessages_de.properties等资源文件,则应指定WEB-INF/messages的基本名称。

您的邮件包文件的实际名称是什么?

我有同样的问题,解决方案是:

  1. messages.properties文件放在源文件夹src / main / resources中

  2. 将Bean定义如下:

        

您看到我将属性与没有.properties的文件messages.properties的名称相同

那是问题^^

您必须将“resources”文件夹添加到“Web部署程序集”。 之后,将“classpath:messages”替换为“messages”。 您需要做的最后一项更改是清理您的项目。

例:

     

这就足够了。 🙂

一个重要的考虑因素是,为了自动重新加载,属性文件不应该在类路径中。 服务器通常会缓存属性,所以如果它在classes文件夹中,它就不会真正有效。 对于每个Spring文档,在classpath:messages的情况下,cachedSeconds不是-1,不会有任何影响。

迟到总比不到好。 我有同样的问题。 这是我解决它的方式。 我的文件名是:

messages_ fr .properties

为法国,因为它是法国springTutotrial。 但是,我住在荷兰。 所以我试着将其重命名为

messages_nl .properties

它的工作原理。 不确定这是一个长期的解决方法,但我们会看到。

对任何将面临这个问题的人。

除了所有答案之外,请确保让Spring框架处理.jsp文件 。 如果直接访问.jsp,则不会处理spring标记,并且您将看到完全相同的错误。 简单地说, 通过控制器公开.jsps

我有同样的问题,但我只是把它留作messages_properties,它解决了这个问题