【发布时间】:2020-07-01 07:31:24
【问题描述】:
我有一个案例类
case class Fare(flightNumber: String, flightDate: LocalDate, amount: Int)
和一个演员
class FareDb extends Actor with ActorLogging {
import FareDb._
var fares: List[Fare] = List()
override def receive: Receive = {
case AddFare(fare) =>
log.info(s"Adding fare $fare")
fares = fares :+ fare
case GetFare(flightNumber, flightDate) =>
log.info(s"Getting Fare for FlightNumber $flightNumber and FlightDate $flightDate")
sender() ! fares.find { fare => (flightNumber == fare.flightNumber & flightDate == fare.flightDate) }
}
}
我也有路线
object FareController extends App with FareJsonProtocol with SprayJsonSupport{
val fareRoutes =
(path("api" / "fare") & get & extractLog) { log =>
parameter(Symbol("flightNumber").as[String],
Symbol("flightDate").as(stringToLocalDate)) { (flightNumber: String, flightDate: LocalDate) =>
log.info(s"Searching for Fare with FlightNumber $flightNumber & FlightDate: $flightDate")
val fareFuture: Future[Option[Fare]] = (fareDb ? GetFare(flightNumber, flightDate)).mapTo[Option[Fare]]
complete(fareFuture)
}
}
}
当我搜索票价并使用航班号和航班日期“询问”Actor 时,它会返回 Future[Option[Fare]]。如果它返回票价,那么一切都很好。我可以像使用 SprayJson 一样使用 complete(fareFuture)。但是如何迎合未来[无]?我想为空结果抛出异常并相应地发送 HttpResponse 。我们如何做到这一点?谢谢。
【问题讨论】: