可以添加通用应用程序过滤器、每个控制器过滤器甚至操作过滤器。看看finatra中的这个过滤器部分。
可以使用每个控制器的过滤器方法来解决 Cors 问题。在 Server.scala 文件中定义了一个过滤器:
import com.twitter.finagle.{Filter, Service, SimpleFilter}
class CorsFilter extends SimpleFilter[Request, Response] {
override def apply(request: Request, service: Service[Request, Response]): Future[Response] = {
service(request).map {
response => response.headerMap
.add("access-control-allow-origin", "*")
.add("access-control-allow-headers", "accept, content-type")
.add("access-control-allow-methods", "GET,HEAD,POST,DELETE,OPTIONS,PUT,PATCH")
response
}
}
然后,在定义服务器的部分中,注册控制器并将刚刚创建的过滤器附加到它:
object ServerMain extends Server
class Server extends HttpServer {
override val name = "com.example.server"
override def configureHttp(router: HttpRouter) {
router
.filter[CommonFilters]
.filter[LoggingMDCFilter[Request, Response]]
.filter[TraceIdMDCFilter[Request, Response]]
.add[CorsFilter, MainController] // see the CorsFilter here
}
}
我希望它有帮助。