如何在scala Controller中实现Secure.Authenticator?

时间:2016-02-01 15:20:35

标签: scala authentication playframework-2.0

我正在遵循本指南 - https://www.playframework.com/documentation/2.1.1/JavaGuide4#Implementing-authenticators

我在Scala中实现了以下身份验证器:

package controllers

import play.mvc.Security
import play.mvc.Http.Context
import play.mvc.Result
import play.mvc.Results

class Secured extends Security.Authenticator {

  override def getUsername(ctx: Context) : String = {
    return ctx.session().get("username");
  }  

  override def onUnauthorized(ctx: Context) : Result = {
    Results.redirect(routes.Application.login())
  }

}

我将它作为注释应用于下面控制器中的hello动作。

package controllers

import services.UserServiceImpl
import models.User._
import play.api.mvc._
import play.mvc.Security.Authenticated

object Application extends Controller {

  def index = Action {
    Ok(views.html.index("Your new application is ready."))
  }

  @Authenticated(classOf[Secured])
  def hello = Action {
    Ok("Hello")
  }

  def login = Action {
    Ok("Login")
  }

}

我正在使用Play 2.4和play.api.mvc.Controller而不是play.mvc.Controller。这是不起作用的原因吗?如何让它与play.api.mvc.Controller一起使用?

1 个答案:

答案 0 :(得分:0)

我认为一个例子可能有助于解释事情。如果您想在Play Scala中使用类似的功能,您可以执行以下操作:

NSURLSession

然后您将在控制器中使用它:

object AuthenticatedAction extends ActionBuilder[Request] {
  def invokeBlock[A](request: Request[A], block: (Request[A]) => Future[Result]) = {
    request.session.get("username") match {
      case Some(user) => block(request)
      case None => Redirect(routes.Application.login())
  }
}