繁体   English   中英

将实体插入数据库后,如何返回它?

[英]How can I return my entity, after it has been inserted into the database?

我使用 model class 作为解决方案用户,并使用身份来控制登录等。

因此,对于我来说要创建身份用户,我需要先创建应用程序用户。 我怎样才能返回这个实体? 或者,我怎样才能返回创建的 ID?

在我的 class 结构下面

授权控制器

 public class AuthControllerController : MainController
    {

        private readonly SignInManager<IdentityUser> _signInManager;
        private readonly UserManager<IdentityUser> _userManager;
        private readonly AppSettings _appSettings;
        private readonly IUserSolutionService _userSolutionService;
        private readonly IUserSolutionRepository _userSolutionRepo;
        private readonly IMapper _mapper;

        public AuthControllerController(IUserIdentity userIdentity,
                                        SignInManager<IdentityUser> signInManager,
                                        UserManager<IdentityUser> userManager,
                                        IOptions<AppSettings> appSettings,
                                        IUserSolutionService userSolutionService,
                                        IUserSolutionRepository userSolutionRepo,
                                        IMapper mapper) : base(userIdentity)
        {
            _signInManager = signInManager;
            _userManager = userManager;
            _appSettings = appSettings.Value;
            _userSolutionService = userSolutionService;
            _userSolutionRepo = userSolutionRepo;
            _mapper = mapper;
        }

        [HttpPost("register")]
        public async Task<ActionResult> Registrar(UserSolutionViewModel registerUser)
        {
            if (!ModelState.IsValid) return BadRequest("Há itens faltando");

            var returnOfRegisterUser = someMethodToReturnId(); //How to do this?

            var user = new IdentityUser()
            {
                Id = registerUser.Id.ToString(), //return the Id of User of App
                UserName = registerUser.Email, //não precisa ser o email, mas, por padrao deixaremos ser o email
                Email = registerUser.Email,
                EmailConfirmed = true //pode ser false e ter a confirmação de email em algum lugar.                

            };            

            var result = await _userManager.CreateAsync(user, registerUser.Password);

            if (result.Succeeded)
            {
                await _signInManager.SignInAsync(user, false); //FALSE neste parametro é se quer persistir esse login
                //return CustomResponse(GerarJwtClaimsAndUser(user.Email)); // este metodo retorna mais dados do usuário e não somente o Token
                //return CustomResponse(GerarJwt());//caso seja necessário gerar o token com as claims, usar o outro método - linha abaixo - 
                return  Ok(GerarJwt());
            }

            return Ok(registerUser);
        }        
}

界面:

public interface IUserSolutionRepository : IRepository<UserSolution>
{       
    Task<UserSolution> GetUserByEmail(string email);
    Task<UserSolution> GetUserByPhone(string countryCode, string areaCode, string phone);
    Task<UserSolution> GetUser(Guid id);
    Task<UserSolution> GetUserAddress(Guid id);
    Task<UserSolution> AddUserSolution(UserSolution user);

}

回购:

 public class UserSolutionRepository : Repository<UserSolution>, IUserSolutionRepository
    {
        public UserSolutionRepository(SolutionDbContext context) : base(context)
        {
            
        }

        ......

        public async Task<UserSolution> AddUserSolution(UserSolution user)
        {
            //Can I return here????
        }
    }
}

我相信,一旦将用户添加到数据库中,只需要在数据库中生成的 Id 即可插入 Identity。 谢谢您的帮助。

如果您使用的是数据库生成的Ids (如IDENTITY ),则会在SaveChangesAsync()之后为您自动填充Id

    public async Task<IActionResult> Create(User user)
    {
        int id = user.Id; // id is 0

        _context.Add(user); 
        await _context.SaveChangesAsync();

        id = user.Id;     // Yes, it has value  
        return View(user);
    }

当使用自动生成的Ids时,实体框架默认遵循每个INSERTSELECT SCOPE_IDENTITY()

测试截图

在此处输入图像描述

在插入用户之前

在此处输入图像描述

插入用户后

在此处输入图像描述

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM