2015-09-16 49 views
7

我有一些問題升級版本春(3.2.6至4.2.1)匹配不變。春4網 - java.lang.IllegalArgumentException異常:沒有了[0]

試圖讓到登錄頁面相關的CSS和JS文件時,我得到500內部服務器錯誤。 在服務器端我看到了異常: 「java.lang.IllegalArgumentException異常:沒有了[0]匹配常量」

調試它後,我看到,在「ResourceHttpRequestHandler.handleRequest()」方法,還有一個供檢查在將任何狀態設置爲響應之前的響應狀態 - 導致'java.lang.IllegalArgumentException:對[0]'異常沒有匹配的常量。

支票已完成: 'ServletWebRequest.isCompatibleWithConditionalRequests(ServletWebRequest.java:244)'

這就是所謂的 'ResourceHttpRequestHandler.handleRequest(ResourceHttpRequestHandler.java:240)'

當狀態改變階段只發生在'writeContent(response,resource)'ResourceHttpRequestHandler.java:271。

我已經找到了解決辦法 - 使用自定義「ResourceHttpRequestHandler」,設置響應狀態200時響應狀態處理請求之前爲0。

任何想法如何解決它在一個更清潔的方式?或者它是一個錯誤?

堆棧跟蹤:

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) 
+1

今天早上我遇到了同樣的問題,從4.1.7升級到4.2.1。我的資源正確標記爲security =「none」。到目前爲止,我還沒有很好的解決方案,並且使用了(希望暫時)添加一個新的「httpStatusFixFilter」,當接收到的代碼爲0時,設置HttpStatus.OK。 – Elegie

+0

@Elegie這正是我所做的。希望我們能找到更好的解決方案... – BobTheBuilder

+0

今天從Spring 3升級到4,並遇到了這個問題。這令人生氣,我無法在任何地方找到解決方案。猜猜我也要用過濾器來解決問題。 –

回答

1

異常消息指示服務器端代碼生成與狀態碼0,這是無效的響應。如果選中的HTTPStatus類的valueOf方法一樣,你會看到異常消息(彈簧網/ src目錄/主/ JAVA /組織/ 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 + "]"); 
    } 

我認爲這是主要的問題上的錯誤堆棧跟蹤: -

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) 

看來你的過濾器是在這些非安全CSS & JS項目活躍。你必須讓他們過濾配置這樣的東西: -

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

注意: - 我認爲你有JS文件夾內classpath的所有JS文件。

+1

我知道它拋出異常。問題是爲什麼狀態碼在這一點上是0。 – BobTheBuilder

+0

你可以分享完整的錯誤堆棧跟蹤以及對項目的一些洞察力,所以我可以更精確地幫助你。 – Avis

+0

堆棧跟蹤已經連接。我的項目是一個包含許多配置文件的彈簧項目,所以我無法將它們全部附加。當我嘗試獲取不安全的css或js文件時發生錯誤 - 並且spring使用ResourceHttpRequestHandler處理它 – BobTheBuilder

1

我相當肯定這是春季的最新版本(4.2和4.2.1)中的錯誤做了緩存的靜態資源內容修改的測試。該行似乎是在此承諾: https://github.com/spring-projects/spring-framework/commit/0175068cab7d294b6cce4369cbd7745dd03198ab#diff-40591a69c61c7ec1f211737fbf40b4ac

它得到走動一點在隨後提交,但是這是我第一次看到有它的內容沒有測試它的存在測試的狀態代碼。

我從降級到4.2.1到4.1.7讓它消失。

編輯:看到@BrianClozel回答,因爲這是固定在4.2.2

+0

感謝Greg向Spring團隊伸出援手;我們寧願爲您解決這個問題,而不是讓您陷入解決方法。這裏記錄了一個問題:https://jira.spring.io/browse/SPR-13516 –

+0

謝謝@BrianClozel。如果它有幫助,我們根本不會觸及或配置ResourceHttpRequestHandler。它只是使用MVC的XML配置:'' –

相關問題