AuthService.cs 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. using Microsoft.AspNetCore.Mvc;
  2. using Microsoft.AspNetCore.Http;
  3. using EasyTemplate.Service.Common;
  4. using EasyTemplate.Tool.Entity;
  5. using EasyTemplate.Tool;
  6. using Microsoft.AspNetCore.Components;
  7. using static EasyTemplate.Tool.Entity.PublicEnum;
  8. using Microsoft.AspNetCore.Authorization;
  9. namespace EasyTemplate.Service;
  10. [AllowAnonymous]
  11. [ApiGroup(ApiGroupNames.Auth)]
  12. public class AuthService : BaseService
  13. {
  14. /// <summary>
  15. /// 注意,非blazor环境,不能使用[Inject]方式注入
  16. /// </summary>
  17. private readonly SqlSugarRepository<SystemUser> _user;
  18. /// <summary>
  19. ///
  20. /// </summary>
  21. private readonly IHttpContextAccessor _contextAccessor;
  22. public AuthService(IHttpContextAccessor contextAccessor, SqlSugarRepository<SystemUser> user)
  23. {
  24. _contextAccessor = contextAccessor;
  25. _user = user;
  26. }
  27. /// <summary>
  28. /// 登录
  29. /// {"username":"admin","password":"123456"}
  30. /// </summary>
  31. /// <param name="input"></param>
  32. /// <returns></returns>
  33. /// <remarks><code>{"username":"admin","password":"123456"}</code></remarks>
  34. [HttpPost]
  35. public async Task<object> Login(LoginInput input)
  36. {
  37. var user = await _user.AsQueryable()
  38. .Where(x => x.Account.Equals(input.Account) && x.Password.Equals(input.Password))
  39. .FirstAsync();
  40. _ = user ?? throw Oops.Oh(ErrorCode.E1000);
  41. //生成Token令牌
  42. var token = Jwt.Serialize(new TokenModelJwt
  43. {
  44. UserId = user.Id,
  45. Name = user.Account,
  46. UserType = PublicEnum.UserType.Admin
  47. });
  48. _contextAccessor.HttpContext.Response.Headers["access-token"] = token;
  49. return token;
  50. }
  51. }