0

我正在学习如何使用 Aqueduct 框架进行身份验证。

在我的 channel.dart 文件中,我有一条路线:

router
  .route('/protected') 
  .link(() => Authorizer.basic(validator))
  .link(() => ProtectedController()); 

但我不知道如何创建validator. 在文档中,我看到我可以在不使用 AuthServer 的情况下制作自定义授权者。代码示例是这样的:

class BasicValidator implements AuthValidator {
  @override
  FutureOr<Authorization> validate<T>(AuthorizationParser<T> parser, T authorizationData, {List<AuthScope> requiredScope}) {}
    var user = await userForName(usernameAndPassword.username);
    if (user.password == hash(usernameAndPassword.password, user.salt)) {
      return Authorization(...);
    }

    return null;
  }
}

我想做一个基本的工作示例,但这是我能得到的最接近的示例:

class BasicValidator implements AuthValidator {
  @override
  FutureOr<Authorization> validate<T>(AuthorizationParser<T> parser, T authorizationData, {List<AuthScope> requiredScope}) {

    final validUsername = 'bob';
    final validPassword = 'password123';

    // How do I get the parsed username?
    // How do I get the parsed password?

    if (parsedUsername == validUsername && parsedPassword == validPassword) {
      // How do I create an Authorization?
      return Authorization(...);
    }

    return null;
  }

  // What is this?
  @override
  List<APISecurityRequirement> documentRequirementsForAuthorizer(APIDocumentContext context, Authorizer authorizer, {List<AuthScope> scopes}) {
    return null;
  }
}

谁能给我看一个基本授权验证器的基本工作示例?

4

1 回答 1

1

authorizationDataAuthBasicCredentials使用时的一个实例Authorizer.basic。这种类型的对象具有从解析请求的“授权”标头派生的字段usernamepassword

Authorization 对象是与授权资源所有者(例如他们的用户 ID)相关的数据的容器。后续控制器使用它来控制授权,无需再次查找授权用户;您应该使用您可用的任何授权信息填充它。

documentRequirementsForAuthorizer在 OpenAPI 文档生成期间使用。使用Authorizer您的验证器的 AN 会将返回的安全要求编码到受保护的 OpenAPI 操作中。

另请参阅http://aqueduct.io/docs/auth/authorizer/#using-authorizers-without-authserver

@override
FutureOr<Authorization> validate<T>(AuthorizationParser<T> parser, T authorizationData, {List<AuthScope> requiredScope}) {

    final validUsername = 'bob';
    final validPassword = 'password123';

    final credentials = authorizationData as AuthBasicCredentials;

    if (credentials.username == validUsername 
    && credentials.password == validPassword) {

      return Authorization(
       null, // no client ID for basic auth 
       await getUserIDFromUsername(validUsername), // This is your problem to solve
       this, // always this
       credentials: credentials // if you want to pass this info along 
       );
    }

    return null;
  }
于 2019-04-29T18:43:27.960 回答