When running Java code that calls Scala, namely the Play library, I'm seeing this error when running the below test code.
java.lang.NoClassDefFoundError: org/codehaus/jackson/map/Deserializers$Base
I looked up Deserializers$Base
to find out it's part of the package, org.codehaus.jackson
. Then, I saw that this package is part of the jackson-mapper-asl
artifactId
.
Java
// Main
Foo foo = new Foo();
foo.do(); // <-- top of stack trace
public class Foo {
public String do() {
List<JsValue> jsonList = new ArrayList<JsValue>();
// populate jsonList
return JsonUtil.build(json); // <-- second line of stack trace
}
Scala
object JsonUtil {
import collection.JavaConverters._
def build(x: java.util.List[JsValue]): String =
Json.obj("bar" -> x.asScala.toList).toString
}
}
After adding this dependency to my POM, I still encountered the above error. Full stack trace:
java.lang.NoClassDefFoundError: org/codehaus/jackson/map/Deserializers$Base
at java.lang.ClassLoader.defineClass1(Native Method)
at java.lang.ClassLoader.defineClass(ClassLoader.java:792)
at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)
at java.net.URLClassLoader.defineClass(URLClassLoader.java:449)
at java.net.URLClassLoader.access$100(URLClassLoader.java:71)
at java.net.URLClassLoader$1.run(URLClassLoader.java:361)
at java.net.URLClassLoader$1.run(URLClassLoader.java:355)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:354)
at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
at play.api.libs.json.JacksonJson$module$.setupModule(JsValue.scala:460)
at org.codehaus.jackson.map.ObjectMapper.registerModule(ObjectMapper.java:444)
at play.api.libs.json.JacksonJson$.<init>(JsValue.scala:464)
at play.api.libs.json.JacksonJson$.<clinit>(JsValue.scala)
at play.api.libs.json.Json$.stringify(Json.scala:48)
at play.api.libs.json.JsValue$class.toString(JsValue.scala:79)
at play.api.libs.json.JsObject.toString(JsValue.scala:158)
at com.workspace.json.JsonUtil$.build(JsonUtil.scala:95)
Note that I've installed play_2.10-2.1.5
and play-iteratees_2.10-2.1.5
libraries using mvn install ...
. Additionally, I added the proper Jackson dependency, but again the above error showed up at run-time.
<dependency>
<groupId>org.codehaus.jackson</groupId>
<artifactId>jackson-mapper-asl</artifactId>
<version>1.9.13</version>
</dependency>