简体   繁体   English

Spring 4 web - java.lang.IllegalArgumentException:[0]没有匹配的常量

[英]Spring 4 web - java.lang.IllegalArgumentException: No matching constant for [0]

I have some problems upgrading spring version (3.2.6 to 4.2.1). 升级spring版本(3.2.6到4.2.1)时遇到一些问题。

I get 500 Internal server error when trying to get css and js files related to login page. 尝试获取与登录页面相关的css和js文件时,我收到500内部服务器错误。 At the server side I see the exception: 'java.lang.IllegalArgumentException: No matching constant for [0]' 在服务器端,我看到了异常:'java.lang.IllegalArgumentException:[0]没有匹配的常量

After debugging it I saw that in 'ResourceHttpRequestHandler.handleRequest()' method there's a check for the response status before setting any status to the response - causing 'java.lang.IllegalArgumentException: No matching constant for [0]' exception. 调试之后,我看到在'ResourceHttpRequestHandler.handleRequest()'方法中,在为响应设置任何状态之前检查响应状态 - 导致'java.lang.IllegalArgumentException:[0]'异常没有匹配常量。

The check is done in: 'ServletWebRequest.isCompatibleWithConditionalRequests(ServletWebRequest.java:244)' 检查完成于:'ServletWebRequest.isCompatibleWithConditionalRequests(ServletWebRequest.java:244)'

which is called in 'ResourceHttpRequestHandler.handleRequest(ResourceHttpRequestHandler.java:240)' 在'ResourceHttpRequestHandler.handleRequest(ResourceHttpRequestHandler.java:240)中调用

When the status change phase happen only in 'writeContent(response, resource)' ResourceHttpRequestHandler.java:271. 当状态改变阶段仅发生在'writeContent(响应,资源)'ResourceHttpRequestHandler.java:271中时。

I've found a workaround - use a custom 'ResourceHttpRequestHandler' that sets the response status 200 when response status is 0 before handling the request. 我找到了一种解决方法 - 使用自定义'ResourceHttpRequestHandler',在响应状态为0之前设置响应状态200,然后再处理请求。

Any idea how to fix it in a cleaner way? 知道如何以更清洁的方式解决它吗? or is it a bug? 还是一个bug?

Stacktrace: 堆栈跟踪:

2015-09-16 17:17:14.964:WARN:oejs.ServletHandler:qtp749664947-21: 
org.springframework.web.util.NestedServletException: Request processing failed; nested exception is java.lang.IllegalArgumentException: No matching constant for [0]
    at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:982)
    at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:861)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:687)
    at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:846)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:790)
    at org.eclipse.jetty.servlet.ServletHolder.handle(ServletHolder.java:711)
    at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1644)
    at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:207)
    at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:184)
    at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:346)
    at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:262)
    at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1632)
    at com.myApp.webapp.RequestParameterToAttributeFilter.doFilter(RequestParameterToAttributeFilter.java:37)
    at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1632)
    at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:207)
    at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:176)
    at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:346)
    at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:262)
    at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1632)
    at com.myApp.webapp.PersonalizationFilter.doFilter(PersonalizationFilter.java:78)
    at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1632)
    at org.springframework.web.filter.HttpPutFormContentFilter.doFilterInternal(HttpPutFormContentFilter.java:87)
    at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
    at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1632)
    at org.springframework.orm.hibernate5.support.OpenSessionInViewFilter.doFilterInternal(OpenSessionInViewFilter.java:151)
    at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
    at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1632)
    at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:85)
    at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
    at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1632)
    at com.myApp.webapp.GenericWrappingFilter.doFilter(GenericWrappingFilter.java:100)
    at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1624)
    at org.eclipse.jetty.servlet.ServletHandler.doHandle(ServletHandler.java:550)
    at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:143)
    at org.eclipse.jetty.security.SecurityHandler.handle(SecurityHandler.java:568)
    at org.eclipse.jetty.server.session.SessionHandler.doHandle(SessionHandler.java:221)
    at org.eclipse.jetty.server.handler.ContextHandler.doHandle(ContextHandler.java:1112)
    at org.eclipse.jetty.servlet.ServletHandler.doScope(ServletHandler.java:479)
    at org.eclipse.jetty.server.session.SessionHandler.doScope(SessionHandler.java:183)
    at org.eclipse.jetty.server.handler.ContextHandler.doScope(ContextHandler.java:1046)
    at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:141)
    at org.eclipse.jetty.server.handler.ContextHandlerCollection.handle(ContextHandlerCollection.java:199)
    at org.eclipse.jetty.server.handler.HandlerCollection.handle(HandlerCollection.java:109)
    at org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:97)
    at org.eclipse.jetty.server.Server.handle(Server.java:462)
    at org.eclipse.jetty.server.HttpChannel.handle(HttpChannel.java:281)
    at org.eclipse.jetty.server.HttpConnection.onFillable(HttpConnection.java:232)
    at org.eclipse.jetty.io.AbstractConnection$1.run(AbstractConnection.java:505)
    at org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:607)
    at org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(QueuedThreadPool.java:536)
    at java.lang.Thread.run(Thread.java:745)
Caused by: 
java.lang.IllegalArgumentException: No matching constant for [0]
    at org.springframework.http.HttpStatus.valueOf(HttpStatus.java:488)
    at org.springframework.web.context.request.ServletWebRequest.isCompatibleWithConditionalRequests(ServletWebRequest.java:244)
    at org.springframework.web.context.request.ServletWebRequest.checkNotModified(ServletWebRequest.java:181)
    at org.springframework.web.servlet.resource.ResourceHttpRequestHandler.handleRequest(ResourceHttpRequestHandler.java:240)
    at org.springframework.web.servlet.mvc.HttpRequestHandlerAdapter.handle(HttpRequestHandlerAdapter.java:51)
    at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:959)
    at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:893)
    at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:970)
    at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:861)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:687)
    at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:846)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:790)
    at org.eclipse.jetty.servlet.ServletHolder.handle(ServletHolder.java:711)
    at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1644)
    at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:207)
    at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:184)
    at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:346)
    at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:262)
    at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1632)
    at com.myApp.webapp.RequestParameterToAttributeFilter.doFilter(RequestParameterToAttributeFilter.java:37)
    at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1632)
    at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:207)
    at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:176)
    at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:346)
    at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:262)
    at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1632)
    at com.myApp.webapp.PersonalizationFilter.doFilter(PersonalizationFilter.java:78)
    at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1632)
    at org.springframework.web.filter.HttpPutFormContentFilter.doFilterInternal(HttpPutFormContentFilter.java:87)
    at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
    at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1632)
    at org.springframework.orm.hibernate5.support.OpenSessionInViewFilter.doFilterInternal(OpenSessionInViewFilter.java:151)
    at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
    at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1632)
    at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:85)
    at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
    at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1632)
    at com.myApp.webapp.GenericWrappingFilter.doFilter(GenericWrappingFilter.java:100)
    at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1624)
    at org.eclipse.jetty.servlet.ServletHandler.doHandle(ServletHandler.java:550)
    at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:143)
    at org.eclipse.jetty.security.SecurityHandler.handle(SecurityHandler.java:568)
    at org.eclipse.jetty.server.session.SessionHandler.doHandle(SessionHandler.java:221)
    at org.eclipse.jetty.server.handler.ContextHandler.doHandle(ContextHandler.java:1112)
    at org.eclipse.jetty.servlet.ServletHandler.doScope(ServletHandler.java:479)
    at org.eclipse.jetty.server.session.SessionHandler.doScope(SessionHandler.java:183)
    at org.eclipse.jetty.server.handler.ContextHandler.doScope(ContextHandler.java:1046)
    at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:141)
    at org.eclipse.jetty.server.handler.ContextHandlerCollection.handle(ContextHandlerCollection.java:199)
    at org.eclipse.jetty.server.handler.HandlerCollection.handle(HandlerCollection.java:109)
    at org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:97)
    at org.eclipse.jetty.server.Server.handle(Server.java:462)
    at org.eclipse.jetty.server.HttpChannel.handle(HttpChannel.java:281)
    at org.eclipse.jetty.server.HttpConnection.onFillable(HttpConnection.java:232)
    at org.eclipse.jetty.io.AbstractConnection$1.run(AbstractConnection.java:505)
    at org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:607)
    at org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(QueuedThreadPool.java:536)
    at java.lang.Thread.run(Thread.java:745)

这已通过SPR-13516修复 ,并随Spring Framework 4.2.2一起提供。

The exception message indicates your server side code generated a response with status code 0, which is invalid. 异常消息表明您的服务器端代码生成了状态代码为0的响应,该响应无效。 If you check valueOf method of HttpStatus class you will see the exception message (spring-web/src/main/java/org/springframework/http/HttpStatus.java) :- 如果你检查HttpStatus类的valueOf方法,你会看到异常消息(spring-web / src / main / java / org / springframework / http / HttpStatus.java): -

public static HttpStatus valueOf(int statusCode) {
        for (HttpStatus status : values()) {
            if (status.value == statusCode) {
                return status;
            }
        }
        throw new IllegalArgumentException("No matching constant for [" + statusCode + "]");
    }

I see this as the main issue on error stacktrace:- 我认为这是错误堆栈跟踪的主要问题: -

at com.myApp.webapp.GenericWrappingFilter.doFilter(GenericWrappingFilter.java:100)
at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1624)
at org.eclipse.jetty.servlet.ServletHandler.doHandle(ServletHandler.java:550)
at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:143)
at org.eclipse.jetty.security.SecurityHandler.handle(SecurityHandler.java:568)
at org.eclipse.jetty.server.session.SessionHandler.doHandle(SessionHandler.java:221)

It seems your filter is active on these non-secured css & js items. 您的过滤器似乎在这些非安全的css&js项目上处于活动状态。 You have to make them filter free with config something like this :- 你必须使用这样的配置使它们免费过滤: -

<http pattern="/css/**" security="none"/>
<http pattern="/login.jsp*" security="none"/>
<http pattern="/js/**" security="none"/>

Note:- i assumed you have all JS files within JS folder on classpath. 注意: - 我假设你在类路径的JS文件夹中有所有JS文件。

I am fairly certain this is a bug in the latest versions (4.2 and 4.2.1) of Spring to do with testing of content modification for caching static resources. 我相当确定这是Spring最新版本(4.2和4.2.1)中的一个错误,用于测试内容修改以缓存静态资源。 The line appears to be in this commit: https://github.com/spring-projects/spring-framework/commit/0175068cab7d294b6cce4369cbd7745dd03198ab#diff-40591a69c61c7ec1f211737fbf40b4ac 该行似乎在此提交中: https//github.com/spring-projects/spring-framework/commit/0175068cab7d294b6cce4369cbd7745dd03198ab#diff-40591a69c61c7ec1f211737fbf40b4ac

It gets move around a bit in subsequent commits, but that is the first time I can see the status code having its content tested without testing its existence. 它在后续提交中会稍微移动一下,但这是我第一次看到状态代码在没有测试其存在的情况下测试其内容。

I downgraded from 4.2.1 to 4.1.7 to make it go away. 我将其从4.2.1降级到4.1.7以使其消失。

EDIT: See answer from @BrianClozel as this is fixed in 4.2.2 编辑:请参阅@BrianClozel的答案,因为这已在4.2.2中修复

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

相关问题 java.lang.IllegalArgumentException:使用RestTemplate时[0]没有匹配的常量 - java.lang.IllegalArgumentException: No matching constant for [0] while using RestTemplate 春季-java.lang.IllegalArgumentException - Spring - java.lang.IllegalArgumentException java.lang.IllegalArgumentException:没有枚举常量 - java.lang.IllegalArgumentException: No enum constant Spring RequestMapping java.lang.IllegalArgumentException错误 - Spring RequestMapping java.lang.IllegalArgumentException error java.lang.IllegalArgumentException - java.lang.IllegalArgumentException java.lang.IllegalArgumentException - java.lang.IllegalArgumentException Spring Boot:java.lang.IllegalArgumentException:找到了多个名为 [spring_web] 的片段 - Spring Boot : java.lang.IllegalArgumentException: More than one fragment with the name [spring_web] was found 什么是处理java.lang.IllegalArgumentException的最佳方法:没有枚举常量 - What is the best way to handle java.lang.IllegalArgumentException: No enum constant hadoop-enum.valueOf-java.lang.IllegalArgumentException:没有枚举常量 - hadoop - enum.valueOf - java.lang.IllegalArgumentException: No enum constant 春季-AWS(无春季启动):java.lang.IllegalArgumentException:不是托管类型 - Spring - AWS (no spring boot): java.lang.IllegalArgumentException: Not a managed type
 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM