You are viewing the documentation for the 2.2.0 release in the 2.2.x series of releases. The latest stable release series is 2.4.x.
§アプリケーションのグローバル設定
§Global オブジェクト
プロジェクト内に Global
オブジェクトを定義すると、アプリケーションのグローバル設定を行うことができます。このオブジェクトはルートパッケージに定義される必要があります。
import play.*;
public class Global extends GlobalSettings {
}
§アプリケーションの起動や停止をインターセプトする
onStart
や onStop
操作をオーバーライドすることで、対応するアプリケーションのライフサイクルイベントの通知を受けることができます。
import play.*;
public class Global extends GlobalSettings {
public void onStart(Application app) {
Logger.info("Application has started");
}
public void onStop(Application app) {
Logger.info("Application shutdown...");
}
}
§アプリケーションのエラーページを提供する
アプリケーションで例外が発生すると、onError
操作が呼び出されます。デフォルトでは、フレームワークに用意されている汎用的なエラーページを表示するようになっていますが、これをオーバーライドすることができます。
import play.*;
import play.mvc.*;
import play.mvc.Http.*;
import play.libs.F.*;
import static play.mvc.Results.*;
public class Global extends GlobalSettings {
public Promise<SimpleResult> onError(RequestHeader request, Throwable t) {
return Promise.<SimpleResult>pure(internalServerError(
views.html.errorPage.render(t)
));
}
}
§存在しないアクションを扱う
フレームワークがリクエストに対応するアクションを見つけられなかった場合、onHandlerNotFound
操作が呼び出されます。
import play.*;
import play.mvc.*;
import play.mvc.Http.*;
import play.libs.F.*;
import static play.mvc.Results.*;
public class Global extends GlobalSettings {
public Promise<SimpleResult> onHandlerNotFound(RequestHeader request) {
return Promise.<SimpleResult>pure(notFound(
views.html.notFoundPage.render(request.uri())
));
}
}
また、ルートは存在するものの、リクエストパラメータをバインドできなかった場合は、onBadRequest
操作が呼び出されます。
import play.*;
import play.mvc.*;
import play.mvc.Http.*;
import play.libs.F.*;
import static play.mvc.Results.*;
public class Global extends GlobalSettings {
public Promise<SimpleResult> onBadRequest(RequestHeader request, String error) {
return Promise.<SimpleResult>pure(badRequest("Don't try to hack the URI!"));
}
}
次ページ: リクエストのインターセプト