ang*_*okh 7 scala playframework playframework-2.3 playframework-2.4
在Play 2.3中,我可以根据不同的请求路径或方法禁用某些过滤器.但是,我在Play 2.4中找不到办法.https://www.playframework.com/documentation/2.4.x/ScalaHttpFilters.如何在Play 2.4 HttpFilters中获得类似的结果.
这是我在Play 2.3中的表现.
object CacheCtrlHeadersFilter extends EssentialFilter {
def apply(action: EssentialAction) = new EssentialAction {
def apply(requestHeader: RequestHeader) = {
action(requestHeader).map { result =>
result.withHeaders(
CACHE_CONTROL -> "no-cache, no-store, must-revalidate, private",
PRAGMA -> "no-cache"
)
}
}
}
}
import play.api.libs.iteratee._
object FilterChainByRequestHeader {
def apply[A](action: EssentialAction, filtersFun: (RequestHeader) => List[EssentialFilter]): EssentialAction = new EssentialAction {
def apply(rh: RequestHeader): Iteratee[Array[Byte], Result] = {
val chain = filtersFun(rh).reverse.foldLeft(action) { (a, i) => i(a) }
chain(rh)
}
}
}
object Global extends GlobalSettings {
val securityFilter = SecurityHeadersFilter()
val defaultFilters = List(securityFilter,
CacheCtrlHeadersFilter)
def filters(rh: RequestHeader) = {
if (rh.method == "OPTIONS") <----------- by method
defaultFilters.filterNot(_.eq(securityFilter))
else if (rh.path.startsWith("/apps/google")) <----------- by path
defaultFilters.filterNot(_.eq(securityFilter))
else defaultFilters
}
override def doFilter(a: EssentialAction): EssentialAction = {
FilterChainByRequestHeader(super.doFilter(a), filters)
}
}
Run Code Online (Sandbox Code Playgroud)
Play 2.4中的HttpFilters中没有RequestHeader
class Filters @Inject() (
securityHeadersFilter: SecurityHeadersFilter,
cacheCtrlHeadersFilter: CacheCtrlHeadersFilter
) extends HttpFilters {
val filters = Seq(securityHeadersFilter, cacheCtrlHeadersFilter)
}
Run Code Online (Sandbox Code Playgroud)
这就是我最终所做的。
class SecurityHeadersFilter extends EssentialFilter {
def apply(action: EssentialAction) = new EssentialAction {
def apply(rh: RequestHeader) = {
action(rh).map { result =>
if (rh.method != "OPTIONS" && !rh.path.startsWith("/apps/google"))
result.withHeaders(
"X-Frame-Options" -> "SAMEORIGIN",
"Content-Security-Policy" -> "default-src * 'self' 'unsafe-inline' 'unsafe-eval' "
)
}
}
}
}
class Filters @Inject() (
gzip: GzipFilter,
cache: CacheCtrlHeadersFilter,
cors: CorsFilter,
security: SecurityHeadersFilter
) extends HttpFilters {
val filters = Seq(gzip, cache, cors, security)
}
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
1095 次 |
最近记录: |