我正在开发一个Play 2.2应用程序,自从我尝试添加我的数据库层以来,事情已经在我身上发生了一些变化.
下面是我的build.sbt依赖项.如你所见,我使用mysql-connector-java和play-slick:
libraryDependencies ++= Seq(
jdbc,
anorm,
cache,
"joda-time" % "joda-time" % "2.3",
"MysqL" % "mysql-connector-java" % "5.1.26",
"com.typesafe.play" %% "play-slick" % "0.5.0.8",
"com.aetrion.flickr" % "flickrapi" % "1.1"
)
我的application.conf中有一些类似的简单数据库内容:
db.default.url="jdbc:MysqL://localhost/myDb"
db.default.driver="com.MysqL.jdbc.Driver"
db.default.user="root"
db.default.pass=""
这是我的Play服务器启动时的样子:
[info] play - Listening for HTTP on /0:0:0:0:0:0:0:0:9000
(Server started, use Ctrl+D to stop and go back to the console...)
[info] Compiling 1 Scala source to C:\bbq\cats\in\space
[info] play - database [default] connected at jdbc:MysqL://localhost/myDb
[info] play - Application started (Dev)
所以,似乎Play可以很好地连接到MysqL数据库(我认为).但是,当我向服务器发出任何请求时,我收到此异常:
[error] p.nettyException - Exception caught in Netty
java.lang.NoSuchMethodError: akka.actor.ActorSystem.dispatcher()Lscala/concurren
t/ExecutionContext;
at play.core.Invoker$.<init>(Invoker.scala:24) ~[play_2.10.jar:2.2.0]
at play.core.Invoker$.<clinit>(Invoker.scala) ~[play_2.10.jar:2.2.0]
at play.api.libs.concurrent.Execution$Implicits$.defaultContext$lzycompu
te(Execution.scala:7) ~[play_2.10.jar:2.2.0]
at play.api.libs.concurrent.Execution$Implicits$.defaultContext(Executio
n.scala:6) ~[play_2.10.jar:2.2.0]
at play.api.libs.concurrent.Execution$.<init>(Execution.scala:10) ~[play
_2.10.jar:2.2.0]
at play.api.libs.concurrent.Execution$.<clinit>(Execution.scala) ~[play_
2.10.jar:2.2.0]
奇怪的是,第二个请求(到完全相同的URL,相同的控制器,没有更改)返回一个不同的错误:
[error] p.nettyException - Exception caught in Netty
java.lang.NoClassDefFoundError: Could not initialize class play.api.libs.concurr
ent.Execution$
at play.core.server.netty.PlayDefaultUpstreamHandler.handleAction$1(Play
DefaultUpstreamHandler.scala:194) ~[play_2.10.jar:2.2.0]
at play.core.server.netty.PlayDefaultUpstreamHandler.messageReceived(Pla
yDefaultUpstreamHandler.scala:169) ~[play_2.10.jar:2.2.0]
at com.typesafe.netty.http.pipelining.HttpPipeliningHandler.messageRecei
ved(HttpPipeliningHandler.java:62) ~[netty-http-pipelining.jar:na]
at org.jboss.netty.handler.codec.http.HttpContentDecoder.messageReceived
(HttpContentDecoder.java:108) ~[netty-3.6.5.Final.jar:na]
at org.jboss.netty.channel.Channels.fireMessageReceived(Channels.java:29
6) ~[netty-3.6.5.Final.jar:na]
at org.jboss.netty.handler.codec.frame.FrameDecoder.unfoldAndFireMessage
Received(FrameDecoder.java:459) ~[netty-3.6.5.Final.jar:na]
我请求的URL /控制器只是呈现一个静态网页,并没有做任何重要的事情.在我开始添加数据库层之前,它工作得很好. I’m rather stuck.非常感谢任何帮助,谢谢.
我正在使用Scala 2.10.2,Play 2.2.0和MysqL Server 5.6.14.0(社区版).
解决方法:
好吧,我终于明白了.我觉得有点像dolt,但我会在这里发布,因为它可能对其他人有用:
在我的项目的早期工作中,我正在尝试其他各种可能的库:Mongo,BSON转换器等.当然,在进行实验时,我将它们添加到我的IDE的项目库依赖项中(我正在使用IntelliJ IDEA 12) .当然,IntelliJ正在下载JAR并将它们放入我项目的lib目录中.但是,在确定了我想要使用的库并从项目依赖项中删除不必要的库之后,IntelliJ没有从项目的lib目录中删除/清除未使用的JAR.这导致了大量不必要的JAR存在,其中一些可能与SBT库相冲突.
简而言之:我清理了Play项目的lib目录,在IDE中仔细检查了项目的库依赖项,并仅重新导入了我真正需要的JAR.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。