AccountController.cs 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223
  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.api.Job;
  15. using wispro.sp.entity;
  16. using wispro.sp.share;
  17. using wispro.sp.share.webViewObject;
  18. namespace wispro.sp.api.Controllers
  19. {
  20. [Route("api/[controller]")]
  21. [ApiController]
  22. public class AccountController : ControllerBase
  23. {
  24. private static List<Staff> CacheList = new List<Staff>();
  25. public IConfiguration Configuration { get; }
  26. spDbContext dbContext;
  27. public AccountController(IConfiguration configuration,spDbContext _dbContext)
  28. {
  29. Configuration = configuration;
  30. dbContext = _dbContext;
  31. }
  32. [HttpGet,HttpPost,Route("Login")]
  33. public userToken Login(loginDto loginUser)
  34. {
  35. //添加验证代码
  36. Staff staff = dbContext.Staffs.Where<Staff>(s => s.Account == loginUser.Name ).FirstOrDefault(); //
  37. if (staff != null && staff.Password == utility.MD5Utility.GetMD5(loginUser.Password))
  38. {
  39. return GetToken(staff);
  40. }
  41. else
  42. {
  43. return new userToken() {
  44. StatusCode = System.Net.HttpStatusCode.NotFound,
  45. Name = null,
  46. Token = null
  47. };
  48. }
  49. }
  50. [Authorize]
  51. [HttpGet, HttpPost, Route("ChangePassword")]
  52. public bool ChangePassword(changePasswordDto dto)
  53. {
  54. Staff staff = dbContext.Staffs.Where<Staff>(s => s.Id == dto.UserId && s.Password == utility.MD5Utility.GetMD5(dto.oldPassword)).FirstOrDefault();
  55. if (staff != null)
  56. {
  57. staff.Password = utility.MD5Utility.GetMD5(dto.newPassword);
  58. dbContext.SaveChanges();
  59. return true;
  60. }
  61. else
  62. {
  63. return false;
  64. }
  65. }
  66. [HttpGet, HttpPost, Route("ResetPassword")]
  67. public ApiSaveResponse ResetPassword(string accountName,string mail)
  68. {
  69. ApiSaveResponse ret = new ApiSaveResponse();
  70. ret.Success = true;
  71. Staff staff = dbContext.Staffs.Where<Staff>(s => s.Account == accountName && s.Mail == mail).FirstOrDefault();
  72. if(staff != null)
  73. {
  74. string strPassword = "";
  75. Random random = new Random();
  76. for (int i = 0; i < 8; i++)
  77. {
  78. strPassword = $"{strPassword}{random.Next(0,9)}";
  79. }
  80. staff.Password = utility.MD5Utility.GetMD5(strPassword);
  81. dbContext.SaveChanges();
  82. string strBody = $"<div style=\"position:absolute;width:800;height:300;margin-top:50px;margin-left:200px;margin-right:200px;box-shadow:0px 0px 3px 3px #ccc \"><div style= \"margin-top: 20px; margin-left:20px;;font-size:14px; \">{staff.Name},你好!</div><div style= \"margin-top: 25px; margin-left:20px;font-size:14px; \"><div>系统已为您重置密码,密码为:{strPassword},请检查并补充缺失数据!</div><div style= \"margin-top: 100px;margin-right:15px; padding-bottom: 20px; font-size:14px;color:#888888;float:right; \">小美集团绩效管理系统</div></div>";
  83. _ = QuartzUtil.AddMailJob("重置密码通知", strBody, staff.Name, staff.Mail);
  84. return ret;
  85. }
  86. else
  87. {
  88. ret.Success = false;
  89. ret.ErrorMessage = "无效的用户名或邮箱";
  90. return ret;
  91. }
  92. }
  93. [HttpGet, HttpPost, Route("Modify")]
  94. public ApiSaveResponse Modify(string accountName,string status, string mail)
  95. {
  96. ApiSaveResponse ret = new ApiSaveResponse();
  97. ret.Success = true;
  98. Staff staff = dbContext.Staffs.Where<Staff>(s => s.Account == accountName).FirstOrDefault();
  99. if (staff != null)
  100. {
  101. staff.Status = status;
  102. staff.Mail = mail;
  103. dbContext.SaveChanges();
  104. return ret;
  105. }
  106. else
  107. {
  108. ret.Success = false;
  109. ret.ErrorMessage = "无效的用户名或邮箱";
  110. return ret;
  111. }
  112. }
  113. [Authorize]
  114. [HttpGet,Route("GetUser")]
  115. public userToken GetUser()
  116. {
  117. if (User.Identity.IsAuthenticated)//如果Token有效
  118. {
  119. var name = User.Claims.First(x => x.Type == ClaimTypes.Name).Value;//从Token中拿出用户ID
  120. //模拟获得Token
  121. spDbContext dbContext = new spDbContext();
  122. Staff staff = dbContext.Staffs.Where<Staff>(s => s.Account == name).FirstOrDefault();
  123. if (staff != null)
  124. {
  125. return GetToken(staff);
  126. }
  127. else
  128. {
  129. return new userToken() {StatusCode=System.Net.HttpStatusCode.NotFound, Name = null, Token = null };
  130. }
  131. }
  132. else
  133. {
  134. return new userToken() {StatusCode= System.Net.HttpStatusCode.NotFound, Name = null, Token = null };
  135. }
  136. }
  137. private userToken GetToken(Staff staff)
  138. {
  139. var claims = new List<Claim>()
  140. {
  141. new Claim("Id",staff.Id.ToString()),
  142. new Claim(ClaimTypes.Name,staff.Name),
  143. new Claim(ClaimTypes.Email,(staff.Mail==null)?"":staff.Mail),
  144. };
  145. var positions = dbContext.DepartmentPositions.Where<DepartmentPosition>(dp => dp.StaffId == staff.Id).ToList();
  146. foreach (var p in positions)
  147. {
  148. claims.Add(new Claim(ClaimTypes.Role, $"[{p.departmentId}]-[{p.PositionId}]"));
  149. }
  150. var key = new SymmetricSecurityKey(Encoding.UTF8.GetBytes(Configuration["jwt:Key"]));
  151. var credential = new SigningCredentials(key, SecurityAlgorithms.HmacSha256);
  152. var expireTime = DateTime.Now.AddHours(5);
  153. var token = new JwtSecurityToken(
  154. issuer: Configuration["jwt:Issuer"],
  155. audience: Configuration["jwt:Audience"],
  156. claims: claims.ToArray(),
  157. notBefore: DateTime.Now,
  158. expires: expireTime,
  159. signingCredentials: credential);
  160. string jwtToken = new JwtSecurityTokenHandler().WriteToken(token);
  161. //建立UserToken物件後回傳client
  162. userToken userToken = new userToken()
  163. {
  164. StatusCode = System.Net.HttpStatusCode.OK,
  165. UserId = staff.Id,
  166. Name = staff.Name,
  167. Token = jwtToken,
  168. ExpireTime = expireTime
  169. };
  170. return userToken;
  171. }
  172. [Authorize]
  173. [HttpGet, HttpPost, Route("GetRoles")]
  174. public List<string> GetRoles(string ResourceId)
  175. {
  176. var Authors = Configuration[$"Authorize:{ResourceId}"];
  177. if (string.IsNullOrEmpty(Authors))
  178. {
  179. return new List<string>();
  180. }
  181. var ret = Authors.Split(new char[] { ',' }, StringSplitOptions.RemoveEmptyEntries);
  182. return ret.ToList<string>();
  183. }
  184. }
  185. }