2017-02-09 7 views
0

私はプレイ&デッドボルトエラー

@SubjectRequired@SubjectNotRequired注釈と私の方法のうちのいずれかを設定するたびに、私は次のスタックトレース(ロードされたページ上のBoNTない!)を取得:

play.api.http.HttpErrorHandlerExceptions$$anon$1: Execution exception[[CompletionException: java.lang.NullPointerException]] 
    at play.api.http.HttpErrorHandlerExceptions$.throwableToUsefulException(HttpErrorHandler.scala:293) 
    at play.api.http.DefaultHttpErrorHandler.onServerError(HttpErrorHandler.scala:220) 
    at play.api.GlobalSettings$class.onError(GlobalSettings.scala:160) 
    at play.api.DefaultGlobal$.onError(GlobalSettings.scala:188) 
    at play.api.http.GlobalSettingsHttpErrorHandler.onServerError(HttpErrorHandler.scala:100) 
    at play.core.server.netty.PlayRequestHandler$$anonfun$2$$anonfun$apply$1.applyOrElse(PlayRequestHandler.scala:100) 
    at play.core.server.netty.PlayRequestHandler$$anonfun$2$$anonfun$apply$1.applyOrElse(PlayRequestHandler.scala:99) 
    at scala.concurrent.Future$$anonfun$recoverWith$1.apply(Future.scala:344) 
    at scala.concurrent.Future$$anonfun$recoverWith$1.apply(Future.scala:343) 
    at scala.concurrent.impl.CallbackRunnable.run(Promise.scala:32) 
Caused by: java.util.concurrent.CompletionException: java.lang.NullPointerException 
    at java.util.concurrent.CompletableFuture.encodeThrowable(CompletableFuture.java:273) 
    at java.util.concurrent.CompletableFuture.completeThrowable(CompletableFuture.java:280) 
    at java.util.concurrent.CompletableFuture.uniCompose(CompletableFuture.java:961) 
    at java.util.concurrent.CompletableFuture$UniCompose.tryFire(CompletableFuture.java:926) 
    at java.util.concurrent.CompletableFuture$Completion.run(CompletableFuture.java:442) 
    at play.core.j.HttpExecutionContext$$anon$2.run(HttpExecutionContext.scala:56) 
    at play.core.j.HttpExecutionContext$$anon$2.run(HttpExecutionContext.scala:56) 
    at akka.dispatch.TaskInvocation.run(AbstractDispatcher.scala:39) 
    at akka.dispatch.ForkJoinExecutorConfigurator$AkkaForkJoinTask.exec(AbstractDispatcher.scala:415) 
    at scala.concurrent.forkjoin.ForkJoinTask.doExec(ForkJoinTask.java:260) 
Caused by: java.lang.NullPointerException: null 
    at be.objectify.deadbolt.java.cache.DefaultSubjectCache.apply(DefaultSubjectCache.java:80) 
    at be.objectify.deadbolt.java.cache.DefaultSubjectCache.apply(DefaultSubjectCache.java:38) 
    at be.objectify.deadbolt.java.ConstraintLogic.getSubject(ConstraintLogic.java:348) 
    at be.objectify.deadbolt.java.ConstraintLogic.subjectTest(ConstraintLogic.java:116) 
    at be.objectify.deadbolt.java.ConstraintLogic.subjectPresent(ConstraintLogic.java:72) 
    at be.objectify.deadbolt.java.actions.SubjectPresentAction.lambda$testSubject$129(SubjectPresentAction.java:91) 
    at java.util.Optional.orElseGet(Optional.java:267) 
    at be.objectify.deadbolt.java.actions.AbstractSubjectAction.lambda$execute$118(AbstractSubjectAction.java:76) 
    at java.util.concurrent.CompletableFuture.uniCompose(CompletableFuture.java:952) 
    at java.util.concurrent.CompletableFuture$UniCompose.tryFire(CompletableFuture.java:926) 

私のコードのルックスこのように:クラスで

は実装DeadboltHandler

@Override 
public CompletionStage<Optional<? extends Subject>> getSubject(Context elContext) { 
    return CompletableFuture.supplyAsync(
     () -> { 
      try { 
       return Optional.ofNullable(da.getUser(Integer.parseInt(elContext.session().get("userId")))); 
      } catch (Exception e) { 
       e.printStackTrace(); 
       return null; 
      } 
     }); 
} 

コンストラクタ持っている:

DataAccess da; 

DeadboltSecureHandler(Database db){ 
    da = new DataAccess(db); 
} 

とクラスで私が台無しにした内容の任意のアイデアHandlerCache

@Inject 
public DeadboltHandlerCache(Database db){ 
    DeadboltHandler defaultHandler = new DeadboltSecureHandler(db); 
    handlers.put(HandlerKeys.DEFAULT.key, defaultHandler); 
} 

@Override 
public DeadboltHandler apply(final String key){ 
    return handlers.get(key); 
} 

@Override 
public DeadboltHandler get(){ 
    return defaultHandler; 
} 

を実装しますか?

答えて

1

いくつか...あなたが使用している

deadboltHandlerがnullであり、このための最も可能性の高い説明はHandlerKeys.DEFAULT.keybe.objectify.deadbolt.java.ConfigKeys.DEFAULT_HANDLER_KEYと同じではありませんです。

あなたがdocumentationをチェックすると、あなたは(あなたが2.5.3よりも古いデッドボルトのバージョンを使用している推測する私をリードする)、次のビットを見つけることができます:

注ConfigKeysの使用。 DEFAULT_HANDLER_KEY - これは、すべての注釈で指定されたデフォルトのハンドラキーです。以前のバージョンのDeadboltでは、アノテーション駆動型の制約ではHandlerCache#apply(DEFAULT_HANDLER_KEY)を使用してハンドラを取得するため、デフォルトハンドラはDEFAULT_HANDLER_KEYに関連付けられていなければなりませんでした。 Deadbolt 2.5.3では、これが改善されました。デフォルトのハンドラキーを使用するアノテーション駆動型の制約では、代わりにHandlerCache#getが使用されます。

、あなたの現在のコードでヒットするつもり次の問題は、次のとおりです。

あなたがnullを返却するとき、あなたはgetSubject方法の契約を破っています。何かがCompletionStage<Optional<? extends Subject>>を返す場合は、CompletionStageにはOptionalが含まれている必要があります。 nullを返す代わりに、Optional.empty()を返します。