播放框架文件上传无该文件异常
Play framework file upload no such file exception
我正在尝试使用 play framework scala 实现文件上传。此代码在开发中运行良好(windows),但在部署时失败(Ubuntu)。
def upload = Action(parse.multipartFormData) { request =>
request.body.file("torrentFile").map { picture =>
import java.io.File
val filename = picture.filename
val contentType = picture.contentType
println(filename)
println(contentType)
picture.ref.moveTo(new File("Files/ppp.rdf"))
Ok("File uploaded")
}.getOrElse {
Redirect(routes.Application.index()).flashing(
"error" -> "Missing file")
}
}
这是我尝试上传文件时遇到的错误
play.api.UnexpectedException: Unexpected exception[NoSuchFileException: /tmp/playtemp5801072751187159177/multipartBody5640251320440161134asTemporaryFile -> Files/ppp.rdf]
at play.api.http.HttpErrorHandlerExceptions$.throwableToUsefulException(HttpErrorHandler.scala:289) ~[com.typesafe.play.play_2.11-2.5.10.jar:2.5.10]
at play.api.http.DefaultHttpErrorHandler.onServerError(HttpErrorHandler.scala:220) ~[com.typesafe.play.play_2.11-2.5.10.jar:2.5.10]
at play.api.GlobalSettings$class.onError(GlobalSettings.scala:160) [com.typesafe.play.play_2.11-2.5.10.jar:2.5.10]
at play.core.j.JavaGlobalSettingsAdapter.play$core$j$JavaGlobalSettingsAdapter$$super$onError(JavaGlobalSettingsAdapter.scala:35) [com.typesafe.play.play_2.11-2.5.10.jar:2.5.10]
at play.core.j.JavaGlobalSettingsAdapter$$anonfun$onError.apply(JavaGlobalSettingsAdapter.scala:35) [com.typesafe.play.play_2.11-2.5.10.jar:2.5.10]
at play.core.j.JavaGlobalSettingsAdapter$$anonfun$onError.apply(JavaGlobalSettingsAdapter.scala:35) [com.typesafe.play.play_2.11-2.5.10.jar:2.5.10]
at scala.Option.getOrElse(Option.scala:121) [org.scala-lang.scala-library-2.11.7.jar:na]
at play.core.j.JavaGlobalSettingsAdapter.onError(JavaGlobalSettingsAdapter.scala:35) [com.typesafe.play.play_2.11-2.5.10.jar:2.5.10]
at play.api.http.GlobalSettingsHttpErrorHandler.onServerError(HttpErrorHandler.scala:100) [com.typesafe.play.play_2.11-2.5.10.jar:2.5.10]
at play.core.server.netty.PlayRequestHandler$$anonfun$$anonfun$apply.applyOrElse(PlayRequestHandler.scala:100) [com.typesafe.play.play-netty-server_2.11-2.5.10.jar:2.5.10]
Caused by: java.nio.file.NoSuchFileException: /tmp/playtemp5801072751187159177/multipartBody5640251320440161134asTemporaryFile -> Files/ppp.rdf
at sun.nio.fs.UnixException.translateToIOException(UnixException.java:86) ~[na:1.8.0_111]
at sun.nio.fs.UnixException.rethrowAsIOException(UnixException.java:102) ~[na:1.8.0_111]
at sun.nio.fs.UnixCopyFile.move(UnixCopyFile.java:457) ~[na:1.8.0_111]
at sun.nio.fs.UnixFileSystemProvider.move(UnixFileSystemProvider.java:262) ~[na:1.8.0_111]
at java.nio.file.Files.move(Files.java:1395) ~[na:1.8.0_111]
at play.api.libs.Files$TemporaryFile.moveTo(Files.scala:102) ~[com.typesafe.play.play_2.11-2.5.10.jar:2.5.10]
at controllers.Upload$$anonfun$upload$$anonfun$apply.apply(Upload.scala:74) ~[untitled10.untitled10-1.0-sans-externalized.jar:na]
at controllers.Upload$$anonfun$upload$$anonfun$apply.apply(Upload.scala:68) ~[untitled10.untitled10-1.0-sans-externalized.jar:na]
at scala.Option.map(Option.scala:146) [org.scala-lang.scala-library-2.11.7.jar:na]
at controllers.Upload$$anonfun$upload.apply(Upload.scala:68) ~[untitled10.untitled10-1.0-sans-externalized.jar:na]
应用程序在 运行 时创建了一些文件和文件夹,目前正在发生这种情况,所以我确定它在目录中没有 Linux 文件权限。
当我转到 /tmp
目录时,我没有看到播放临时文件。
我正在使用 intellij 中的 play 2.5。
首先,尝试给出完整路径而不是Files
,比如/var/webapps/your-app/files
。
运行 应用程序作为 root
临时(使用 sudo)并确保 Files
(/var/webapps/your-app/files) 文件夹存在于磁盘上。
如果应用程序作为 root
运行,则表明权限存在问题。确保应用 运行 的用户具有 read/write 对 /tmp
的访问权限和对 Files
的写入权限。
我正在尝试使用 play framework scala 实现文件上传。此代码在开发中运行良好(windows),但在部署时失败(Ubuntu)。
def upload = Action(parse.multipartFormData) { request =>
request.body.file("torrentFile").map { picture =>
import java.io.File
val filename = picture.filename
val contentType = picture.contentType
println(filename)
println(contentType)
picture.ref.moveTo(new File("Files/ppp.rdf"))
Ok("File uploaded")
}.getOrElse {
Redirect(routes.Application.index()).flashing(
"error" -> "Missing file")
}
}
这是我尝试上传文件时遇到的错误
play.api.UnexpectedException: Unexpected exception[NoSuchFileException: /tmp/playtemp5801072751187159177/multipartBody5640251320440161134asTemporaryFile -> Files/ppp.rdf]
at play.api.http.HttpErrorHandlerExceptions$.throwableToUsefulException(HttpErrorHandler.scala:289) ~[com.typesafe.play.play_2.11-2.5.10.jar:2.5.10]
at play.api.http.DefaultHttpErrorHandler.onServerError(HttpErrorHandler.scala:220) ~[com.typesafe.play.play_2.11-2.5.10.jar:2.5.10]
at play.api.GlobalSettings$class.onError(GlobalSettings.scala:160) [com.typesafe.play.play_2.11-2.5.10.jar:2.5.10]
at play.core.j.JavaGlobalSettingsAdapter.play$core$j$JavaGlobalSettingsAdapter$$super$onError(JavaGlobalSettingsAdapter.scala:35) [com.typesafe.play.play_2.11-2.5.10.jar:2.5.10]
at play.core.j.JavaGlobalSettingsAdapter$$anonfun$onError.apply(JavaGlobalSettingsAdapter.scala:35) [com.typesafe.play.play_2.11-2.5.10.jar:2.5.10]
at play.core.j.JavaGlobalSettingsAdapter$$anonfun$onError.apply(JavaGlobalSettingsAdapter.scala:35) [com.typesafe.play.play_2.11-2.5.10.jar:2.5.10]
at scala.Option.getOrElse(Option.scala:121) [org.scala-lang.scala-library-2.11.7.jar:na]
at play.core.j.JavaGlobalSettingsAdapter.onError(JavaGlobalSettingsAdapter.scala:35) [com.typesafe.play.play_2.11-2.5.10.jar:2.5.10]
at play.api.http.GlobalSettingsHttpErrorHandler.onServerError(HttpErrorHandler.scala:100) [com.typesafe.play.play_2.11-2.5.10.jar:2.5.10]
at play.core.server.netty.PlayRequestHandler$$anonfun$$anonfun$apply.applyOrElse(PlayRequestHandler.scala:100) [com.typesafe.play.play-netty-server_2.11-2.5.10.jar:2.5.10]
Caused by: java.nio.file.NoSuchFileException: /tmp/playtemp5801072751187159177/multipartBody5640251320440161134asTemporaryFile -> Files/ppp.rdf
at sun.nio.fs.UnixException.translateToIOException(UnixException.java:86) ~[na:1.8.0_111]
at sun.nio.fs.UnixException.rethrowAsIOException(UnixException.java:102) ~[na:1.8.0_111]
at sun.nio.fs.UnixCopyFile.move(UnixCopyFile.java:457) ~[na:1.8.0_111]
at sun.nio.fs.UnixFileSystemProvider.move(UnixFileSystemProvider.java:262) ~[na:1.8.0_111]
at java.nio.file.Files.move(Files.java:1395) ~[na:1.8.0_111]
at play.api.libs.Files$TemporaryFile.moveTo(Files.scala:102) ~[com.typesafe.play.play_2.11-2.5.10.jar:2.5.10]
at controllers.Upload$$anonfun$upload$$anonfun$apply.apply(Upload.scala:74) ~[untitled10.untitled10-1.0-sans-externalized.jar:na]
at controllers.Upload$$anonfun$upload$$anonfun$apply.apply(Upload.scala:68) ~[untitled10.untitled10-1.0-sans-externalized.jar:na]
at scala.Option.map(Option.scala:146) [org.scala-lang.scala-library-2.11.7.jar:na]
at controllers.Upload$$anonfun$upload.apply(Upload.scala:68) ~[untitled10.untitled10-1.0-sans-externalized.jar:na]
应用程序在 运行 时创建了一些文件和文件夹,目前正在发生这种情况,所以我确定它在目录中没有 Linux 文件权限。
当我转到 /tmp
目录时,我没有看到播放临时文件。
我正在使用 intellij 中的 play 2.5。
首先,尝试给出完整路径而不是Files
,比如/var/webapps/your-app/files
。
运行 应用程序作为 root
临时(使用 sudo)并确保 Files
(/var/webapps/your-app/files) 文件夹存在于磁盘上。
如果应用程序作为 root
运行,则表明权限存在问题。确保应用 运行 的用户具有 read/write 对 /tmp
的访问权限和对 Files
的写入权限。