【问题标题】:Play: migration 2.5 to 2.6: error ProvisionException播放:迁移 2.5 到 2.6:错误 ProvisionException
【发布时间】:2017-10-23 12:41:01
【问题描述】:

从 Play 版本 2.5 迁移到 2.6 时出现错误。

以下是我已应用的操作列表:

  • sbt clean

  • sbt 编译

  • sbt 更新

  • sbt 日食

    我遇到了这个异常

    ProvisionException:无法配置,请参阅以下错误:

    1) 注入构造函数时出错,java.lang.NoClassDefFoundError: org/pac4j/play/scala/Security$class 在 controllers.EntityController.(EntityController.scala:50) 在 controllers.EntityController.class(EntityController.scala:50) 同时定位controllers.EntityController 对于 router.Routes.(Routes.scala:50) 的第四个参数 定位 router.Routes 时 同时定位 play.api.inject.RoutesProvider 同时定位 play.api.routing.Router play.api.http.JavaCompatibleHttpRequestHandler.(HttpRequestHandler.scala:222)的第一个参数 同时定位 play.api.http.JavaCompatibleHttpRequestHandler 同时定位 play.api.http.HttpRequestHandler 对于 play.api.DefaultApplication.(Application.scala:236) 的第 6 个参数 在 play.api.DefaultApplication.class(Application.scala:235) 定位 play.api.DefaultApplication 同时定位 play.api.Application 引起:java.lang.NoClassDefFoundError: org/pac4j/play/scala/Security$class 在 controllers.EntityController.(EntityController.scala:60) 在 controllers.EntityController$$FastClassByGuice$$f46ad4b6.newInstance() 在 com.google.inject.internal.DefaultConstructionProxyFactory$FastClassProxy.newInstance(DefaultConstructionProxyFactory.java:89) 在 com.google.inject.internal.ConstructorInjector.provision(ConstructorInjector.java:111) 在 com.google.inject.internal.ConstructorInjector.construct(ConstructorInjector.java:90) 在 com.google.inject.internal.ConstructorBindingImpl$Factory.get(ConstructorBindingImpl.java:268) 在 com.google.inject.internal.ProviderToInternalFactoryAdapter$1.call(ProviderToInternalFactoryAdapter.java:46) 在 com.google.inject.internal.InjectorImpl.callInContext(InjectorImpl.java:1092) 在 com.google.inject.internal.ProviderToInternalFactoryAdapter.get(ProviderToInternalFactoryAdapter.java:40) 在 com.google.inject.internal.SingletonScope$1.get(SingletonScope.java:194) 在 com.google.inject.internal.InternalFactoryToProviderAdapter.get(InternalFactoryToProviderAdapter.java:41) 在 com.google.inject.internal.SingleParameterInjector.inject(SingleParameterInjector.java:38) 在 com.google.inject.internal.SingleParameterInjector.getAll(SingleParameterInjector.java:62) 在 com.google.inject.internal.ConstructorInjector.provision(ConstructorInjector.java:110) 在 com.google.inject.internal.ConstructorInjector.construct(ConstructorInjector.java:90) 在 com.google.inject.internal.ConstructorBindingImpl$Factory.get(ConstructorBindingImpl.java:268) 在 com.google.inject.internal.InjectorImpl$2$1.call(InjectorImpl.java:1019) 在 com.google.inject.internal.InjectorImpl.callInContext(InjectorImpl.java:1092) 在 com.google.inject.internal.InjectorImpl$2.get(InjectorImpl.java:1015) 在 com.google.inject.internal.InjectorImpl.getInstance(InjectorImpl.java:1054) 在 play.api.inject.guice.GuiceInjector.instanceOf(GuiceInjectorBuilder.scala:409) 在 play.api.inject.ContextClassLoaderInjector$$anonfun$instanceOf$3.apply(Injector.scala:118) 在 play.api.inject.ContextClassLoaderInjector.withContext(Injector.scala:126) 在 play.api.inject.ContextClassLoaderInjector.instanceOf(Injector.scala:118) 在 play.api.inject.RoutesProvider$$anonfun$2.apply(BuiltinModule.scala:104) 在 play.api.inject.RoutesProvider$$anonfun$2.apply(BuiltinModule.scala:104) 在 scala.Option.fold(Option.scala:158) 在 play.api.inject.RoutesProvider.get$lzycompute(BuiltinModule.scala:104) 在 play.api.inject.RoutesProvider.get(BuiltinModule.scala:100) 在 play.api.inject.RoutesProvider.get(BuiltinModule.scala:99) 在 com.google.inject.internal.ProviderInternalFactory.provision(ProviderInternalFactory.java:81) 在 com.google.inject.internal.BoundProviderFactory.provision(BoundProviderFactory.java:72) 在 com.google.inject.internal.ProviderInternalFactory.circularGet(ProviderInternalFactory.java:61) 在 com.google.inject.internal.BoundProviderFactory.get(BoundProviderFactory.java:62) 在 com.google.inject.internal.SingleParameterInjector.inject(SingleParameterInjector.java:38) 在 com.google.inject.internal.SingleParameterInjector.getAll(SingleParameterInjector.java:62) 在 com.google.inject.internal.ConstructorInjector.provision(ConstructorInjector.java:110) 在 com.google.inject.internal.ConstructorInjector.construct(ConstructorInjector.java:90) 在 com.google.inject.internal.ConstructorBindingImpl$Factory.get(ConstructorBindingImpl.java:268) 在 com.google.inject.internal.FactoryProxy.get(FactoryProxy.java:56) 在 com.google.inject.internal.SingleParameterInjector.inject(SingleParameterInjector.java:38) 在 com.google.inject.internal.SingleParameterInjector.getAll(SingleParameterInjector.java:62) 在 com.google.inject.internal.ConstructorInjector.provision(ConstructorInjector.java:110) 在 com.google.inject.internal.ConstructorInjector.construct(ConstructorInjector.java:90) 在 com.google.inject.internal.ConstructorBindingImpl$Factory.get(ConstructorBindingImpl.java:268) 在 com.google.inject.internal.ProviderToInternalFactoryAdapter$1.call(ProviderToInternalFactoryAdapter.java:46) 在 com.google.inject.internal.InjectorImpl.callInContext(InjectorImpl.java:1092) 在 com.google.inject.internal.ProviderToInternalFactoryAdapter.get(ProviderToInternalFactoryAdapter.java:40) 在 com.google.inject.internal.SingletonScope$1.get(SingletonScope.java:194) 在 com.google.inject.internal.InternalFactoryToProviderAdapter.get(InternalFactoryToProviderAdapter.java:41) 在 com.google.inject.internal.FactoryProxy.get(FactoryProxy.java:56) 在 com.google.inject.internal.InjectorImpl$2$1.call(InjectorImpl.java:1019) 在 com.google.inject.internal.InjectorImpl.callInContext(InjectorImpl.java:1085) 在 com.google.inject.internal.InjectorImpl$2.get(InjectorImpl.java:1015) 在 com.google.inject.internal.InjectorImpl.getInstance(InjectorImpl.java:1054) 在 play.api.inject.guice.GuiceInjector.instanceOf(GuiceInjectorBuilder.scala:409) 在 play.api.inject.guice.GuiceInjector.instanceOf(GuiceInjectorBuilder.scala:404) 在 play.api.inject.ContextClassLoaderInjector$$anonfun$instanceOf$2.apply(Injector.scala:117) 在 play.api.inject.ContextClassLoaderInjector.withContext(Injector.scala:126) 在 play.api.inject.ContextClassLoaderInjector.instanceOf(Injector.scala:117) 在 play.api.inject.guice.GuiceApplicationBuilder.build(GuiceApplicationBuilder.scala:137) 在 play.api.inject.guice.GuiceApplicationLoader.load(GuiceApplicationLoader.scala:21) 在 play.core.server.DevServerStart$$anonfun$mainDev$1$$anon$1$$anonfun$1.apply(DevServerStart.scala:174) 在 play.core.server.DevServerStart$$anonfun$mainDev$1$$anon$1$$anonfun$1.apply(DevServerStart.scala:171) 在 play.utils.Threads$.withContextClassLoader(Threads.scala:21) 在 play.core.server.DevServerStart$$anonfun$mainDev$1$$anon$1.reload(DevServerStart.scala:171) 在 play.core.server.DevServerStart$$anonfun$mainDev$1$$anon$1.get(DevServerStart.scala:124) 在 play.core.server.AkkaHttpServer.play$core$server$AkkaHttpServer$$modelConversion(AkkaHttpServer.scala:183) 在 play.core.server.AkkaHttpServer.play$core$server$AkkaHttpServer$$handleRequest(AkkaHttpServer.scala:189) 在 play.core.server.AkkaHttpServer$$anonfun$5.apply(AkkaHttpServer.scala:106) 在 play.core.server.AkkaHttpServer$$anonfun$5.apply(AkkaHttpServer.scala:106) 在 akka.stream.impl.fusing.MapAsync$$anon$23.onPush(Ops.scala:1172) 在 akka.stream.impl.fusing.GraphInterpreter.processPush(GraphInterpreter.scala:499) 在 akka.stream.impl.fusing.GraphInterpreter.processEvent(GraphInterpreter.scala:462) 在 akka.stream.impl.fusing.GraphInterpreter.execute(GraphInterpreter.scala:368) 在 akka.stream.impl.fusing.GraphInterpreterShell.runBatch(ActorGraphInterpreter.scala:571) 在 akka.stream.impl.fusing.GraphInterpreterShell$AsyncInput.execute(ActorGraphInterpreter.scala:457) 在 akka.stream.impl.fusing.GraphInterpreterShell.processEvent(ActorGraphInterpreter.scala:546) 在 akka.stream.impl.fusing.ActorGraphInterpreter.akka$stream$impl$fusing$ActorGraphInterpreter$$processEvent(ActorGraphInterpreter.scala:725) 在 akka.stream.impl.fusing.ActorGraphInterpreter$$anonfun$receive$1.applyOrElse(ActorGraphInterpreter.scala:740) 在 akka.actor.Actor$class.aroundReceive(Actor.scala:514) 在 akka.stream.impl.fusing.ActorGraphInterpreter.aroundReceive(ActorGraphInterpreter.scala:650) 在 akka.actor.ActorCell.receiveMessage(ActorCell.scala:527) 在 akka.actor.ActorCell.invoke(ActorCell.scala:496) 在 akka.dispatch.Mailbox.processMailbox(Mailbox.scala:257) 在 akka.dispatch.Mailbox.run(Mailbox.scala:224) 在 akka.dispatch.Mailbox.exec(Mailbox.scala:234) 在 akka.dispatch.forkjoin.ForkJoinTask.doExec(ForkJoinTask.java:260) 在 akka.dispatch.forkjoin.ForkJoinPool$WorkQueue.runTask(ForkJoinPool.java:1339) 在 akka.dispatch.forkjoin.ForkJoinPool.runWorker(ForkJoinPool.java:1979) 在 akka.dispatch.forkjoin.ForkJoinWorkerThread.run(ForkJoinWorkerThread.java:107) 引起:java.lang.ClassNotFoundException:org.pac4j.play.scala.Security$class 在 java.net.URLClassLoader.findClass(URLClassLoader.java:381) 在 java.lang.ClassLoader.loadClass(ClassLoader.java:424) 在 java.lang.ClassLoader.loadClass(ClassLoader.java:357) ... 91 更多

使用Security的类是这样的

@Singleton
class EntityController @Inject() (val controllerComponents: ControllerComponents,
                                  val config: Config,
                                  val entities: EntityRepository,
                                  val configextractor: ConfigExtractor,
                                  val calendars: CalendarRepository,
                                  val kpis: KpiExtractor,
                                  val authz: EntityAuthorizer,
                                  val playSessionStore: PlaySessionStore,
                                  val searchService: SearchService,
                                  implicit val ec: ComputeExecutionContext
                                 ) extends BaseController with Security[CommonProfile] with KpiAware{

我写了文件 sbt。

name := """fons"""
organization := "com.luxottica.retail"

version := "1.0-SNAPSHOT"

lazy val root = (project in file(".")).enablePlugins(PlayScala)

scalaVersion := "2.11.8"

// Dependencies
libraryDependencies ++= Seq(
  ws,
  filters,
  cacheApi,
  openId,
  guice,
  "commons-io" % "commons-io" % "2.5",
  "com.github.romix.akka" %% "akka-kryo-serialization" % "0.5.0",
  "com.github.simonedeponti" %% "play26-lettuce" % "0.1",
  "joda-time" % "joda-time" % "2.9.9",
  "org.mongodb.scala" %% "mongo-scala-driver" % "2.1.0",
  "org.pac4j" % "play-pac4j" % "4.0.0",
  "org.pac4j" % "pac4j-core" % "2.1.0",
  "org.pac4j" % "pac4j-http" % "2.1.0",
  "org.pac4j" % "pac4j-jwt" % "2.1.0" exclude("commons-io" , "commons-io"),
  "org.pac4j" % "pac4j-ldap" % "2.1.0",  
  "com.microsoft.azure" % "applicationinsights-core" % "1.0.10",
  "com.microsoft.azure" % "applicationinsights-logging-logback" % "1.0.10",
  "com.github.t3hnar" %% "scala-bcrypt" % "3.0",
  "org.scalariform" %% "scalariform" % "0.2.3"
)

// Test dependencies
libraryDependencies ++= Seq(
  "org.scalatestplus.play" %% "scalatestplus-play" % "2.0.0" % Test,
  "org.mockito" % "mockito-all" % "1.10.19" % Test,
  "junit" % "junit" % "4.12" % Test,
  "org.scalaz" %% "scalaz-core" % "7.1.1" % Test
)


resolvers ++= Seq(
  "snapshots" at "http://oss.sonatype.org/content/repositories/snapshots",
  "releases"  at "http://oss.sonatype.org/content/repositories/releases",
  "Scalaz Bintray Repo" at "http://dl.bintray.com/scalaz/releases",
  "Simone's repos" at "https://dl.bintray.com/simonedeponti/maven"
)

routesGenerator := InjectedRoutesGenerator

scalacOptions += "-deprecation"

evictionWarningOptions in update := EvictionWarningOptions.default.withWarnTransitiveEvictions(false)


// Adds additional packages into Twirl
//TwirlKeys.templateImports += "com.luxottica.retail.controllers._"

// Adds additional packages into conf/routes
// play.sbt.routes.RoutesKeys.routesImport += "com.luxottica.retail.binders._"

assemblyMergeStrategy in assembly := {
  case m if m.toLowerCase.endsWith("manifest.mf")          => MergeStrategy.discard
  case m if m.toLowerCase.matches("meta-inf.*\\.sf$")      => MergeStrategy.discard
  case "log4j.properties"                                  => MergeStrategy.discard
  case m if m.toLowerCase.startsWith("meta-inf/services/") => MergeStrategy.filterDistinctLines
  case "reference.conf"                                    => MergeStrategy.concat
  case _                                                   => MergeStrategy.first
}

有什么需要改变的??

【问题讨论】:

    标签: scala dependency-injection playframework-2.6


    【解决方案1】:

    我们遇到了同样的问题,我们修复了它,将 Scala 升级到 2.12

    https://github.com/pac4j/play-pac4j/issues/207

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2013-09-01
      • 1970-01-01
      • 2017-05-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多