问题描述
HttpContext.wait调用后,异步中的当前null.
HttpContext.Current null in async after await calls.
这是我的代码:
if (!string.IsNullOrEmpty(securityGroupName))
{
// To remove the domain name from the security group name.
string securityGroupDisplayName = securityGroupName.Split('\\')[1];
string serviceSecurityGroupId = await this.graphApiClient.GetGroupIdAsync(securityGroupDisplayName).ConfigureAwait(false);
if (!string.IsNullOrEmpty(serviceSecurityGroupId))
{
Task securityGroupRoleAddTask = this.CheckMembershipAndAddRole(serviceSecurityGroupId, userId, securityGroupName);
Task flightAdminRoleAddTask = this.CheckMembershipAndAddRole(FlightAdminSecurityGroupId, userId, FlightAdminRoleName);
Task.WaitAll(securityGroupRoleAddTask, flightAdminRoleAddTask);
}
else
{
LoggingUtilities.Logger.TraceInformation("Azure AD id does not exist for the security group: {0}.", securityGroupName);
await this.CheckMembershipAndAddRole(FlightAdminSecurityGroupId, userId, FlightAdminRoleName).ConfigureAwait(false);
}
}
else
{
LoggingUtilities.Logger.TraceInformation("Security group name is not valid, checking for flight admin role for the user: {0}.", userAlias);
await this.CheckMembershipAndAddRole(FlightAdminSecurityGroupId, userId, FlightAdminRoleName).ConfigureAwait(false);
}
// Add the flight privileged users role to be able to verify the user is authorized for the role.
string flightPrivilegedUsersRoleName = RoleRepository.Instance.GetByName(Constants.FlightPrivilegedUsersRoleKey).Name;
if (!this.roles.Contains(flightPrivilegedUsersRoleName, StringComparer.OrdinalIgnoreCase))
{
LoggingUtilities.Logger.TraceInformation("Adding flight privileged users to roles list for the user: {0}.", userAlias);
this.roles.Add(flightPrivilegedUsersRoleName);
}
if (userAlias != null)
{
LoggingUtilities.Logger.TraceInformation("Check security group memberships and assign roles for the user: {0}.", userAlias);
var newPrincipal = new GenericPrincipal(new GenericIdentity(userAlias), this.roles.ToArray());
Thread.CurrentPrincipal = newPrincipal;
HttpContext.Current.User = newPrincipal;
}
有关web.config条目中以下条目的建议没有帮助:
The recommendations about the following entries in the web.config entries did not help:
<system.web>
<compilation debug="false" targetFramework="4.5" />
<httpRuntime targetFramework="4.5" enableVersionHeader="false" requestPathInvalidCharacters="<,>,%,&,\,?" />
</system.web>
<appSettings>
<add key="aspnet:UseTaskFriendlySynchronizationContext" value="true" />
</appSettings>
任何有关解决此问题的建议将不胜感激.
Any recommendations on how to fix this would be appreciated.
推荐答案
删除您的.ConfigureAwait(false)
调用.它们是导致您麻烦的原因.调用.ConfigureAwait(false)
时,它告诉C#您不在乎要使用哪个线程来完成异步调用.您最终遇到另一个没有HttpContext.Current
上下文的线程,因为它是线程池线程,而不是ASP.NET线程.
Remove your .ConfigureAwait(false)
calls. They are what causing you trouble. When you call .ConfigureAwait(false)
, it tells C# that you don't care which thread to use for the completion of async call. You end up in another thread that has doesn't have HttpContext.Current
context, since it's a thread pool thread, not ASP.NET thread.
这篇关于HttpContext.Current在等待调用后在异步中为null的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!