AccountController.cs 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  1. using Microsoft.AspNetCore.Authorization;
  2. using Microsoft.AspNetCore.Mvc;
  3. using Microsoft.Extensions.Configuration;
  4. using Microsoft.IdentityModel.Tokens;
  5. using System;
  6. using System.Collections.Generic;
  7. using System.Configuration;
  8. using System.Data;
  9. using System.IdentityModel.Tokens.Jwt;
  10. using System.Linq;
  11. using System.Security.Claims;
  12. using System.Text;
  13. using System.Threading.Tasks;
  14. using wispro.sp.entity;
  15. using wispro.sp.share.webViewObject;
  16. namespace wispro.sp.api.Controllers
  17. {
  18. [Route("api/[controller]")]
  19. [ApiController]
  20. public class AccountController : ControllerBase
  21. {
  22. private static List<Staff> CacheList = new List<Staff>();
  23. public IConfiguration Configuration { get; }
  24. spDbContext dbContext;
  25. public AccountController(IConfiguration configuration,spDbContext _dbContext)
  26. {
  27. Configuration = configuration;
  28. dbContext = _dbContext;
  29. }
  30. [HttpGet,HttpPost,Route("Login")]
  31. public userToken Login(loginDto loginUser)
  32. {
  33. //添加验证代码
  34. Staff staff = dbContext.Staffs.Where<Staff>(s => s.Account == loginUser.Name && s.Password == utility.MD5Utility.GetMD5(loginUser.Password)).FirstOrDefault();
  35. if(staff != null)
  36. {
  37. return GetToken(staff);
  38. }
  39. else
  40. {
  41. return new userToken() {
  42. StatusCode = System.Net.HttpStatusCode.NotFound,
  43. Name = null,
  44. Token = null
  45. };
  46. }
  47. }
  48. [Authorize]
  49. [HttpGet, HttpPost, Route("ChangePassword")]
  50. public bool ChangePassword(changePasswordDto dto)
  51. {
  52. Staff staff = dbContext.Staffs.Where<Staff>(s => s.Id == dto.UserId && s.Password == utility.MD5Utility.GetMD5(dto.oldPassword)).FirstOrDefault();
  53. if (staff != null)
  54. {
  55. staff.Password = utility.MD5Utility.GetMD5(dto.newPassword);
  56. dbContext.SaveChanges();
  57. return true;
  58. }
  59. else
  60. {
  61. return false;
  62. }
  63. }
  64. [Authorize]
  65. [HttpGet,Route("GetUser")]
  66. public userToken GetUser()
  67. {
  68. if (User.Identity.IsAuthenticated)//如果Token有效
  69. {
  70. var name = User.Claims.First(x => x.Type == ClaimTypes.Name).Value;//从Token中拿出用户ID
  71. //模拟获得Token
  72. spDbContext dbContext = new spDbContext();
  73. Staff staff = dbContext.Staffs.Where<Staff>(s => s.Account == name).FirstOrDefault();
  74. if (staff != null)
  75. {
  76. return GetToken(staff);
  77. }
  78. else
  79. {
  80. return new userToken() {StatusCode=System.Net.HttpStatusCode.NotFound, Name = null, Token = null };
  81. }
  82. }
  83. else
  84. {
  85. return new userToken() {StatusCode= System.Net.HttpStatusCode.NotFound, Name = null, Token = null };
  86. }
  87. }
  88. private userToken GetToken(Staff staff)
  89. {
  90. var claims = new List<Claim>()
  91. {
  92. new Claim("Id",staff.Id.ToString()),
  93. new Claim(ClaimTypes.Name,staff.Name),
  94. new Claim(ClaimTypes.Email,(staff.Mail==null)?"":staff.Mail),
  95. };
  96. var positions = dbContext.DepartmentPositions.Where<DepartmentPosition>(dp => dp.StaffId == staff.Id).ToList();
  97. foreach (var p in positions)
  98. {
  99. claims.Add(new Claim(ClaimTypes.Role, $"[{p.departmentId}]-[{p.PositionId}]"));
  100. }
  101. var key = new SymmetricSecurityKey(Encoding.UTF8.GetBytes(Configuration["jwt:Key"]));
  102. var credential = new SigningCredentials(key, SecurityAlgorithms.HmacSha256);
  103. var expireTime = DateTime.Now.AddHours(5);
  104. var token = new JwtSecurityToken(
  105. issuer: Configuration["jwt:Issuer"],
  106. audience: Configuration["jwt:Audience"],
  107. claims: claims.ToArray(),
  108. notBefore: DateTime.Now,
  109. expires: expireTime,
  110. signingCredentials: credential);
  111. string jwtToken = new JwtSecurityTokenHandler().WriteToken(token);
  112. //建立UserToken物件後回傳client
  113. userToken userToken = new userToken()
  114. {
  115. StatusCode = System.Net.HttpStatusCode.OK,
  116. UserId = staff.Id,
  117. Name = staff.Name,
  118. Token = jwtToken,
  119. ExpireTime = expireTime
  120. };
  121. return userToken;
  122. }
  123. [Authorize]
  124. [HttpGet, HttpPost, Route("GetRoles")]
  125. public List<string> GetRoles(string ResourceId)
  126. {
  127. var Authors = Configuration[$"Authorize:{ResourceId}"];
  128. if (string.IsNullOrEmpty(Authors))
  129. {
  130. return new List<string>();
  131. }
  132. var ret = Authors.Split(new char[] { ',' }, StringSplitOptions.RemoveEmptyEntries);
  133. return ret.ToList<string>();
  134. }
  135. }
  136. }