【问题标题】:Play Framework: Stream file content to S3Play Framework:将文件内容流式传输到 S3
【发布时间】:2015-12-16 02:44:20
【问题描述】:

我正在尝试通过以下方式使用 Play 的 EssentialAction 将文件内容流式传输到 S3:

  def upload(fileName: String) = EssentialAction { request =>
    val (iteratee, enumerator) = Concurrent.joined[Array[Byte]]
    blobStore.streamToStore(fileName, enumerator) //consumes the enumerator, streams to S3 and returns Future[Unit]
    iteratee.map { _ =>
      Logger.debug(s"Successfully uploaded file=$fileName")
      Created(Json.obj("id" -> fileName))
    }
  }

如果blobStore.streamToStore 流式传输成功,则上述方法有效,但如果流式传输时出现任何错误,则请求永远不会完成,在iteratee 上执行recover 也无济于事。有人可以说明在这种情况下如何处理错误吗?

【问题讨论】:

    标签: scala amazon-s3 playframework


    【解决方案1】:

    我只需要在错误时完成使用枚举器:

    blobStore.streamToStore(fileName, enumerator).recover {
      case throwable =>
        /* consume the enumerator for request to complete */
        enumerator |>> Iteratee.consume[Array[Byte]]().map(_ => throw throwable)
    }
    iteratee.map { _ =>
      Logger.debug(s"Successfully uploaded file=$fileName")
      Created(Json.obj("id" -> fileName))
    }.recover {
      case NonFatal(throwable) => 
         InternalServerError(Results.EmptyContent())
    }
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2017-03-05
      • 2018-02-18
      • 1970-01-01
      • 1970-01-01
      • 2014-03-19
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多