[英]How to implement Akka HTTP Request Post Client Headers Authorization
我正在尝试为发布请求实现 Akka http 客户端,其中授权将在 header 中来自 Z03D476861AFCCFA85181 我无法授权,以下是我的代码
def main(args: Array[String]) {
implicit val system: ActorSystem = ActorSystem()
implicit val materializer: ActorMaterializer = ActorMaterializer()
implicit val executionContext: ExecutionContextExecutor = system.dispatcher
val requestHeader = scala.collection.immutable.Seq(RawHeader("Authorization", "admin"))
val requestHandler: HttpRequest => HttpResponse = {
case HttpRequest(POST, Uri.Path("/GetTrackerData"), requestHeader, entity, _) =>
val chunk = Unmarshal(entity).to[DeviceLocationData]
val deviceLocationData = Await.result(chunk, 1.second)
val responseArray = "Authorized"
HttpResponse(entity = HttpEntity(ContentTypes.`application/json`, responseArray)
)
case r: HttpRequest =>
println(r.uri.toString())
r.discardEntityBytes() // important to drain incoming HTTP Entity stream
HttpResponse(404, entity = "Unknown resource!")
}
val bindingFuture = Http().bindAndHandleSync(requestHandler, "0.0.0.0", 7070)
println(s"iot engine api live at 0.0.0.0:7070")
sys.addShutdownHook({
println("ShutdownHook called")
bindingFuture
.flatMap(_.unbind()) // trigger unbinding from the port
.onComplete(_ => system.terminate()) // and shutdown when done
})
}
无论我从 postman 给出什么值。 它服务于请求。 我在跳过什么?
我的用例是仅在授权后显示结果
您正在HttpRequest
上进行模式匹配。
您在那里使用的requestHeader
不是您之前指定的,而是来自 HttpRequest 本身的标头。
解决它的一种方法是检查标头中的值:
case HttpRequest(HttpMethods.POST, Uri.Path("/GetTrackerData"), headers, entity, _)
if (headers.exists(h => h.name == "Authorization" && h.value == "admin")) =>
这是一个问题:
case HttpRequest(POST, Uri.Path("/GetTrackerData"), requestHeader, entity, _) =>
这与requestHeader
的当前值不匹配,它会创建一个新值requestHeader
,其中包含HttpRequest
的当前标头。 所以这个匹配不会检查 header 的Authorization
字段。 您必须手动执行此操作。
更一般地说,值得关注 Akka HTTP 中的Route
支持,作为实现服务器的更清洁和更强大的方式。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.