2016-11-08 19 views
0

古いプロジェクトのフレームワークをアップグレードしています。アップデートには、いくつかのメジャーバージョン伴う: - > 5.2.4 Hibernate 5.2.4、Spring 4.3.3、Struts 2.5.5への更新後のConcurrentModificationException

  • 春2.1 - > 2.5.5
  • 春セキュリティ2.xの - > 4.3.3
  • のStruts 2.1

    1. にHibernate 3.1を - > 4.1.3
    2. のApache Commonsのコレクション3.2.1 - > 3.2.2

    JDK更新を受けなかった、私たちが使用しているJavaの8けれどもI(必要に応じての4.xへの更新が可能です)ソルクがなかったと思う更新前にJava 8の機能を使用しています。

    など、私はコンパイラに寄りかかっていたと私は、フレームワークのためのDTDを更新し、すべてのクラス参照を固定

    最後のプロジェクトは、わずか数非推奨worningsとエラーなしでコンパイルされます。しかし、私がインデックスページをロードするとすぐに、ログインプロンプトで、私は以下のエラーが表示されます。

    以下のコードでは、Spring/Strut/Hibernateの一部ではないクラスが4つしかありませんが、SpringセキュリティでdoFilterを呼び出すだけです。単純な委任。リストやハッシュマップを作成、返却、または繰り返しはしません。

    アイデアをいただければ幸いです。以下の完全なスタックトレース。ありがとうございました。

    SEVERE: Servlet.service() for servlet [default] in context with path [/FeedXLWebapp] threw exception 
    java.util.ConcurrentModificationException 
        at java.util.HashMap$HashIterator.nextNode(HashMap.java:1437) 
        at java.util.HashMap$KeyIterator.next(HashMap.java:1461) 
        at org.apache.commons.collections.iterators.IteratorEnumeration.nextElement(IteratorEnumeration.java:76) 
        at java.util.ResourceBundle.handleKeySet(ResourceBundle.java:1854) 
        at java.util.ResourceBundle.containsKey(ResourceBundle.java:1807) 
        at org.springframework.context.support.ResourceBundleMessageSource.getStringOrNull(ResourceBundleMessageSource.java:291) 
        at org.springframework.context.support.ResourceBundleMessageSource.resolveCodeWithoutArguments(ResourceBundleMessageSource.java:131) 
        at org.springframework.context.support.AbstractMessageSource.getMessageInternal(AbstractMessageSource.java:218) 
        at org.springframework.context.support.AbstractMessageSource.getMessage(AbstractMessageSource.java:136) 
        at org.springframework.context.support.AbstractApplicationContext.getMessage(AbstractApplicationContext.java:1249) 
        at org.springframework.context.support.MessageSourceAccessor.getMessage(MessageSourceAccessor.java:83) 
        at org.springframework.security.access.vote.AffirmativeBased.decide(AffirmativeBased.java:84) 
        at org.springframework.security.access.intercept.AbstractSecurityInterceptor.beforeInvocation(AbstractSecurityInterceptor.java:233) 
        at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:124) 
        at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:91) 
        at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:331) 
        at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:115) 
        at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:331) 
        at org.springframework.security.web.authentication.AnonymousAuthenticationFilter.doFilter(AnonymousAuthenticationFilter.java:111) 
        at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:331) 
        at au.com.xprime.feedxl.accounts.security.spring.AuthenticationPostProcessingFilter.doFilterHttp(AuthenticationPostProcessingFilter.java:33) 
        at au.com.xprime.feedxl.accounts.security.spring.AuthenticationPostProcessingFilter.doFilter(AuthenticationPostProcessingFilter.java:22) 
        at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:331) 
        at org.springframework.security.web.authentication.rememberme.RememberMeAuthenticationFilter.doFilter(RememberMeAuthenticationFilter.java:150) 
        at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:331) 
        at org.springframework.security.web.authentication.AbstractAuthenticationProcessingFilter.doFilter(AbstractAuthenticationProcessingFilter.java:200) 
        at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:331) 
        at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:121) 
        at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:331) 
        at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:105) 
        at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:331) 
        at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:214) 
        at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:177) 
        at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:346) 
        at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:262) 
        at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:243) 
        at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) 
        at au.com.xprime.feedxl.accounts.auth.filters.BrowserCheckFilter.doFilter(BrowserCheckFilter.java:32) 
        at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:243) 
        at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) 
        at au.com.xprime.webapp.filters.ResponseCacheControlFilter.doFilter(ResponseCacheControlFilter.java:102) 
        at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:243) 
        at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) 
        at org.tuckey.web.filters.urlrewrite.RuleChain.handleRewrite(RuleChain.java:176) 
        at org.tuckey.web.filters.urlrewrite.RuleChain.doRules(RuleChain.java:145) 
        at org.tuckey.web.filters.urlrewrite.UrlRewriter.processRequest(UrlRewriter.java:92) 
        at org.tuckey.web.filters.urlrewrite.UrlRewriteFilter.doFilter(UrlRewriteFilter.java:389) 
        at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:243) 
        at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) 
        at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:222) 
        at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:123) 
        at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:502) 
        at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:171) 
        at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:100) 
        at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:953) 
        at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118) 
        at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:408) 
        at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1041) 
        at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:603) 
        at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:312) 
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) 
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) 
        at java.lang.Thread.run(Thread.java:745) 
    
  • +0

    JDKおよび/またはApache Commons Collectionsをアップグレードしたかどうかを確認してください。はいの場合はどのバージョンですか? –

    +0

    @ Bond-JavaBondあなたが求めているjdkとライブラリのバージョンで投稿を更新しました。私もcommons-collections 4.1ですばやく実行しようとしましたが、3.2.2と4.1の間でかなり変更されたようです。私は、より良いアイデアの欠如で、コモンズコレクション4.1で遊ぶだろう、多分それはうまくいくだろう。 –

    +0

    Okies ..すでにJDK 8を使用していたので、JDK 8がConcurrentModificationExceptionにつながったいくつかの機能拡張を持っているので、別の問題と思われます –

    答えて

    0

    So.私はこれを考えました。問題は、連鎖したメッセージフェッチャークラスでした。

    オブジェクトのコレクション(HashMapなど)があり、このコレクション内のオブジェクトの1つが同じコレクションに新しい要素を追加しようとすると、同時変更例外がスローされるようです。

    関連する問題