Microsoft Identity має методи розширення, які викликають методи асинхронізації синхронно. Наприклад, існує метод GenerateUserIdentityAsync () і рівний CreateIdentity ()
Якщо ви подивитеся на UserManagerExtensions.CreateIdentity (), це виглядає приблизно так:
public static ClaimsIdentity CreateIdentity<TUser, TKey>(this UserManager<TUser, TKey> manager, TUser user,
string authenticationType)
where TKey : IEquatable<TKey>
where TUser : class, IUser<TKey>
{
if (manager == null)
{
throw new ArgumentNullException("manager");
}
return AsyncHelper.RunSync(() => manager.CreateIdentityAsync(user, authenticationType));
}
Тепер давайте подивимося, що робить AsyncHelper.RunSync
public static TResult RunSync<TResult>(Func<Task<TResult>> func)
{
var cultureUi = CultureInfo.CurrentUICulture;
var culture = CultureInfo.CurrentCulture;
return _myTaskFactory.StartNew(() =>
{
Thread.CurrentThread.CurrentCulture = culture;
Thread.CurrentThread.CurrentUICulture = cultureUi;
return func();
}).Unwrap().GetAwaiter().GetResult();
}
Отже, це ваша обгортка для асинхронного методу. І, будь ласка, не читайте дані з Result - це потенційно заблокує ваш код у ASP.
Є й інший спосіб - який для мене підозрілий, але ви також можете це врахувати
Result r = null;
YourAsyncMethod()
.ContinueWith(t =>
{
r = t.Result;
})
.Wait();