【问题标题】:Error injecting constructor, java.nio.file.AccessDeniedException [duplicate]注入构造函数时出错,java.nio.file.AccessDeniedException [重复]
【发布时间】:2018-05-19 19:35:25
【问题描述】:

我遇到了一个异常 (java.nio.file.AccessDeniedException),但我不知道它背后的原因。

play.http.secret.keyprod.conf 中不正确时是否会发生这种情况,或者这是其他一些凭据不正确的症状?

Oops, cannot start the server.
com.google.inject.CreationException: Unable to create injector, see the following errors:

1) Error injecting constructor, java.nio.file.AccessDeniedException: /tmp/playtemp5604435787006203928
  at play.api.libs.Files$DefaultTemporaryFileCreator.<init>(Files.scala:145)
  at play.api.libs.Files$DefaultTemporaryFileCreator.class(Files.scala:142)
  while locating play.api.libs.Files$DefaultTemporaryFileCreator
  while locating play.api.libs.Files$TemporaryFileCreator    
Caused by: java.nio.file.AccessDeniedException: /tmp/playtemp5604435787006203928

【问题讨论】:

  • 问题与凭据无关。问题是无法创建或更新文件/tmp/playtemp5604435787006203928。您在哪个操作系统上运行?
  • 感谢@RobinGreen 这实际上是问题所在。

标签: java playframework nio ioexception


【解决方案1】:

看来您的应用程序无法在系统上进行文件操作,所以:

文件名/路径:仔细检查应用程序中使用的文件名和路径。

prod.conf:我不知道你的prod.conf 中有什么,但我主要将它用于其他api 的环境变量,例如AWS;或数据库凭据。所以我不认为prod.conf 造成了您的问题;除非您添加了生产超级用户凭据;这让我想到了最后一点。

您的应用程序不应是超级用户:请注意,您不应让您的应用程序执行“sudo/superuser”操作(例如,更新底层操作系统)。所以,如果你这样做,请避免它。如果造成混乱,那么您最终可能会被锁定在生产环境之外。当然,这里的例外是,如果您的 Web 应用程序是集群管理系统;例如,那么显然它可能需要执行超级用户操作。

【讨论】:

  • 谢谢@Dave Rose。目录/文件权限是问题所在。在我的情况下,prod.conf 和应用程序不是超级用户签出。
  • @abby 不用担心,很高兴你能解决这个问题。
猜你喜欢
  • 2019-05-25
  • 2017-04-05
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2021-05-13
  • 1970-01-01
  • 2012-03-09
  • 1970-01-01
相关资源
最近更新 更多