2013-10-02 17 views
8

Próbuję utworzyć prosty login oparty na próbce Zentask - zentask - playframework, jednak po kliknięciu przycisku logowania wywołującego akcje Application.authenticate, podaje wyjątek czasu wykonywania. Mam oznaczone linię - błądPlayframework: [RuntimeException: java.lang.reflect.InvocationTargetException]

[RuntimeException: java.lang.reflect.InvocationTargetException] 

Application.java

public class Application extends Controller { 

......... 

public static class Login 
{ 
    public String email; 
    public String password; 

    public String validate() 
    { 
     if (User.authenticate(email, password) == null) { 
      return "Invalid user or password"; 
     } 
     return null; 
    } 
} 

    public static Result authenticate() 
    { 
     Form<Login> loginForm = form(Login.class).bindFromRequest(); //--- error 
     if(loginForm.hasErrors()) { 
      return badRequest(login.render(loginForm)); 
     } else { 
      session("email", loginForm.get().email); 
      return redirect(
       routes.Application.index() 
      ); 
     } 
    } 
} 

Rozumiem, że ma coś wspólnego z funkcji sprawdzania poprawności logowania w klasie, bo kiedy usunąć wywołanie Użytkownika. uwierzytelnianie w funkcji sprawdzania poprawności działa bez błędu. Ale nie jestem w stanie tego rozgryźć.

klasa Użytkownik jest -

@Entity 
public class User extends Model 
{ 
    @Id 
    @Constraints.Required 
    @Formats.NonEmpty 
    public String userId; 

    @OneToOne(cascade=CascadeType.PERSIST) 
    AccountDetails accDetails; 


    public static Model.Finder<String,User> find = new Model.Finder<String,User>(String.class, User.class); 



    // Authenticate the user details 
    public static User authenticate(String email, String password) 
    { 
     String tempId = AccountDetails.authenticate(email, password).userId; 

     return find.ref(tempId); 
    } 

    .. . . . . . . 

} 

i AccountDetails Class -

@Entity 
public class AccountDetails extends Model 
{ 
    @Id 
    String userId; 

    @Constraints.Required 
    String emailId; 

    @Constraints.Required 
    String password; 

    public static Model.Finder<String,AccountDetails> find = 
      new Model.Finder<String,AccountDetails>(String.class, AccountDetails.class); 


    public static AccountDetails authenticate(String email, String password) 
    {  
     return find.where() 
      .eq("email", email) 
      .eq("password", password) 
      .findUnique(); 
    } 

} 

Każda pomoc będzie bardzo mile widziane.

Bardzo dużo.

+0

Brak deklaracji importu, brak śladu stosu wyjątku, kod fragmentu. Odpowiedź na takie pytanie jest dość trudna, z wyjątkiem tego, że już poradziłeś sobie z takim problemem. –

Odpowiedz

4

muszę zakładać przydzieleniu ale jeśli to jest to, co wyglądało jak StackTrace:

play.api.Application$$anon$1: Execution exception[[RuntimeException: java.lang.reflect.InvocationTargetException]] 
       at play.api.Application$class.handleError(Application.scala:293) ~[play_2.10.jar:2.2.3] 
       at play.api.DefaultApplication.handleError(Application.scala:399) [play_2.10.jar:2.2.3] 
       at play.core.server.netty.PlayDefaultUpstreamHandler$$anonfun$3$$anonfun$applyOrElse$3.apply(PlayDefaultUpstreamHandler.scala:264) [play_2.10.jar:2.2.3] 
       at play.core.server.netty.PlayDefaultUpstreamHandler$$anonfun$3$$anonfun$applyOrElse$3.apply(PlayDefaultUpstreamHandler.scala:264) [play_2.10.jar:2.2.3] 
       at scala.Option.map(Option.scala:145) [scala-library.jar:na] 
       at play.core.server.netty.PlayDefaultUpstreamHandler$$anonfun$3.applyOrElse(PlayDefaultUpstreamHandler.scala:264) [play_2.10.jar:2.2.3] 
     ... 
     Caused by: java.lang.NullPointerException: null 
       at models.User.authenticate(User.java:26) ~[na:na] 
       at controllers.Application$Login.validate(Application.java:50) ~[na:na] 
       at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[na:1.8.0_05] 
       at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) ~[na:1.8.0_05] 
       at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[na:1.8.0_05] 
       at java.lang.reflect.Method.invoke(Method.java:483) ~[na:1.8.0_05] 

następnie przyczyną problemu jest rzeczywiście zasugerował przez NPE w swojej klasie obsługi. Jeśli wprowadzisz fałszywe poświadczenia, wyszukiwarka niczego nie znajdzie i zwróci wartość null w AccountDetails.authenticate().

Więc w sposób poniżej ciebie nie sprawdzić nieważną i spróbować uzyskać identyfikator użytkownika, który powoduje NPE:

public static User authenticate(String email, String password) { 
    String tempId = AccountDetails.authenticate(email, password).userId; 

    return find.ref(tempId); 
} 

Jeśli tylko sprawdzić dla wartości null prawidłowo dostaniesz żądaną funkcjonalność:

public static User authenticate(String email, String password) { 
    User user = null; 

    AccountDetails accountDetails = AccountDetails.authenticate(email, password); 
    if (accountDetails != null) { 
     user = find.ref(accountDetails.userId); 
    } 

    return user; 
}