出现这个错误通常是由于在进行AddToRolesAsync操作时,EF(Entity Framework)上下文连接已经被关闭。
解决这个问题的方法是,在进行AddToRolesAsync操作之前,首先确定EF上下文连接没有被关闭:
var user = await UserManager.FindByIdAsync(userId); var roles = await UserManager.GetRolesAsync(userId); var result = await UserManager.AddToRolesAsync(user.Id, new[] { "Role1", "Role2" }); if (result.Succeeded) { //操作成功 }
这段代码中,首先通过UserManager对象获取要进行角色授权的用户信息,并获取该用户已有的角色列表。接下来调用 UserManager.AddToRolesAsync 方法,将新增的角色列表添加到用户使用中。
通过判断result.Succeeded的返回值,可以判断操作是否成功。
最后重点,在EF操作之后,需要将EF上下文连接手动保持打开状态:
myDbContext.Database.Connection.Open();
这样就可以避免 “无效操作:连接已关闭” 错误的出现了。