本文整理汇总了C#中IAuthenticationProvider.GetByUsername方法的典型用法代码示例。如果您正苦于以下问题:C# IAuthenticationProvider.GetByUsername方法的具体用法?C# IAuthenticationProvider.GetByUsername怎么用?C# IAuthenticationProvider.GetByUsername使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类IAuthenticationProvider
的用法示例。
在下文中一共展示了IAuthenticationProvider.GetByUsername方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: ReadCredentials
public PipelineContinuation ReadCredentials(ICommunicationContext context)
{
if (_resolver.HasDependency(typeof(IAuthenticationProvider)))
{
_authentication = _resolver.Resolve<IAuthenticationProvider>();
var header = ReadBasicAuthHeader(context);
if (header != null)
{
var credentials = _authentication.GetByUsername(header.Username);
if (_authentication.ValidatePassword(credentials, header.Password))
{
IIdentity id = new GenericIdentity(credentials.Username, "Basic");
context.User = new GenericPrincipal(id, credentials.Roles);
}
}
}
return PipelineContinuation.Continue;
}
示例2: ReadCredentials
public PipelineContinuation ReadCredentials(ICommunicationContext context)
{
if (!_resolver.HasDependency(typeof(IAuthenticationProvider)))
return PipelineContinuation.Continue;
_authentication = _resolver.Resolve<IAuthenticationProvider>();
DigestHeader authorizeHeader = GetDigestHeader(context);
if (authorizeHeader == null)
return PipelineContinuation.Continue;
string digestUri = GetAbsolutePath(authorizeHeader.Uri);
if (digestUri != context.Request.Uri.AbsolutePath)
return ClientError(context);
Credentials creds = _authentication.GetByUsername(authorizeHeader.Username);
if (creds == null)
return NotAuthorized(context);
var checkHeader = new DigestHeader(authorizeHeader)
{
Password = creds.Password,
Uri = authorizeHeader.Uri
};
string hashedDigest = checkHeader.GetCalculatedResponse(context.Request.HttpMethod);
if (authorizeHeader.Response == hashedDigest)
{
IIdentity id = new GenericIdentity(creds.Username, "Digest");
context.User = new GenericPrincipal(id, creds.Roles);
return PipelineContinuation.Continue;
}
return NotAuthorized(context);
}