[英]How to apply a global filter in playframework
使用@before時,它僅用於一個類。 如何在playframework中應用全局過濾器? 因此,一個過濾器用於所有控制器類。
一個簡單的解決方案是為所有控制器擴展一個基本控制器,並在基本控制器中使用@Before。
另一種選擇(更好的解決方案,因為它更靈活)是使用@With注釋。 播放文檔中的示例是
例:
public class Secure extends Controller {
@Before
static void checkAuthenticated() {
if(!session.containsKey("user")) {
unAuthorized();
}
}
}
在另一個控制器上:
@With(Secure.class)
public class Admin extends Application {
...
}
這意味着Admin控制器將處理Secure控制器中包含的所有攔截器(@ Before,@ After,@Finally)。
我通過在GlobalSettings類中全局處理傳入的請求來做到這一點:
這描述了這個類: http : //www.playframework.org/documentation/2.0/JavaGlobal
這描述了您想要覆蓋的方法。 http://www.playframework.org/documentation/2.0/JavaInterceptors
這是我在自己的項目中使用它的一個例子(當然,這是你正在尋找的簡化版本):
@Override
public play.mvc.Action onRequest(play.mvc.Http.Request request, java.lang.reflect.Method method) {
if (request.path().startsWith("/secret/locked")) {
return new Action.Simple() {
@Override
public Result call(play.mvc.Http.Context ctx) throws Throwable {
return redirect(routes.Application.forbidden());
}
};
}
return super.onRequest(request, method);
}
您可以簡單地使用PlayPlugin來解決此問題。 有關詳細信息,請參見此處
擴展所有控制器的基本控制器並在基本控制器中使用@Before不是一個好的解決方案。
您可以擴展過濾器或essensialfilter .eg
class filter1 extends Filter {}
並將filter1應用於Global
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.