2017-07-26 8 views
0

Quand je l'utilisateur assemblage de SBT, il affiche une erreur comme ceci:scala.MatchError: org apache communs io IOCase.class (de java.lang.String classe) dans la société SBT + Assemblée

[error] (*:assembly) scala.MatchError: org\apache\commons\io\IOCase.class (of class java.lang.String) 

et ce sont mes configurations:

1, assembly.sbt:

import AssemblyKeys._ 
assemblySettings 
mergeStrategy in assembly := { 
    case PathList("org", "springframework", [email protected]_*) => MergeStrategy.last 
} 

2, bulid.sbt

import AssemblyKeys._ 
lazy val root = (project in file(".")). 
    settings(
    name := "DmpRealtimeFlow", 
    version := "1.0", 
    scalaVersion := "2.11.8", 
    libraryDependencies += "com.jd.ads.index" % "ad_index_dmp_common" % "0.0.4-SNAPSHOT", 
    libraryDependencies += "org.apache.spark" % "spark-core_2.11" % "2.1.0" % "provided", 
    libraryDependencies += "org.apache.spark" % "spark-sql_2.11" % "2.1.0" % "provided", 
    libraryDependencies += "org.apache.spark" % "spark-streaming_2.11" % "2.1.0" % "provided", 
    libraryDependencies += "mysql" % "mysql-connector-java" % "5.1.8", 
    libraryDependencies += "org.springframework" % "spring-beans" % "3.1.0.RELEASE", 
    libraryDependencies += "org.springframework" % "spring-context" % "3.1.0.RELEASE", 
    libraryDependencies += "org.springframework" % "spring-core" % "3.1.0.RELEASE", 
    libraryDependencies += "org.springframework" % "spring-orm" % "3.1.0.RELEASE", 
    libraryDependencies += "org.mybatis" % "mybatis" % "3.2.1" % "compile", 
    libraryDependencies += "org.mybatis" % "mybatis-spring" % "1.2.2", 
    libraryDependencies += "c3p0" % "c3p0" % "0.9.1.2" 
) 

3, des outils du projet:

sbt:0.13.5 
assembly:0.11.2 
java:1.7 
scala:2.11.8 

toute aide?

Répondre

0

Le problème peut être le cas par défaut manquant dans mergeStrategy dans le bloc de montage:

case x => 
     val oldStrategy = (assemblyMergeStrategy in assembly).value 
     oldStrategy(x) 

En outre, mergeStrategy est dépréciée et assemblyMergeStrategy doit être utilisé à la place.

Fondamentalement, le

{ 
    case PathList("org", "springframework", [email protected]_*) => MergeStrategy.last 
} 

est une fonction partielle String => MergeStrategy défini pour un seul type d'entrées, à savoir pour les classes avec le préfixe de paquet "org \ springframework". Cependant, il est appliqué à tous les fichiers de classe du projet et le premier qui ne correspond pas au préfixe ci-dessus (org \ apache \ commons \ io \ IOCase.class) provoque MatchError.