UserController.java 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184
  1. package com.api.base.controll;
  2. import com.api.core.config.AuthUser;
  3. import com.api.base.config.auth.JwtTokenUtil;
  4. import com.api.base.model.Role;
  5. import com.api.base.model.User;
  6. import com.api.base.service.UserService;
  7. import com.api.common.JSONUtils;
  8. import com.api.common.wx.WxCommon;
  9. import com.api.core.controller.Ctrl;
  10. import com.api.core.annotation.PowerEnable;
  11. import com.api.core.response.Result;
  12. import com.api.core.response.ResultGenerator;
  13. import com.github.pagehelper.PageHelper;
  14. import com.github.pagehelper.PageInfo;
  15. import io.swagger.annotations.Api;
  16. import io.swagger.annotations.ApiImplicitParam;
  17. import io.swagger.annotations.ApiImplicitParams;
  18. import io.swagger.annotations.ApiOperation;
  19. import org.springframework.cache.annotation.CacheEvict;
  20. import org.springframework.cache.annotation.Caching;
  21. import org.springframework.security.core.Authentication;
  22. import org.springframework.web.bind.annotation.*;
  23. import tk.mybatis.mapper.entity.Condition;
  24. import tk.mybatis.mapper.entity.Example;
  25. import javax.annotation.Resource;
  26. import java.util.HashMap;
  27. import java.util.List;
  28. import java.util.Map;
  29. /**
  30. * Created by CodeGenerator on 2019/03/25.
  31. */
  32. @PowerEnable(name = "账号管理",url = "/user")
  33. @Api(value = "账号管理", tags = {"账号管理"})
  34. @RestController
  35. @RequestMapping(value = "/user")
  36. public class UserController extends Ctrl {
  37. @Resource
  38. private UserService userService;
  39. @Resource
  40. private JwtTokenUtil jwtTokenUtil;
  41. @ApiOperation(value = "注册", tags = {"账号管理"}, notes = "注册")
  42. @PostMapping(value = "/registered", name = "注册")
  43. public Result registered(@RequestParam String username,
  44. @RequestParam String password,
  45. @RequestParam String mobileNumber,
  46. @RequestParam Byte gender,
  47. @RequestParam String email,
  48. @RequestParam String nickname,
  49. @RequestParam String avatar) {
  50. return userService.registered(username,password,mobileNumber,gender,email,nickname,avatar);
  51. }
  52. @ApiOperation(value = "用户列表", tags = {"账号管理"}, notes = "用户列表")
  53. @ApiImplicitParams({
  54. @ApiImplicitParam(name = "where", value = "条件json", dataType = "String", paramType = "query"),
  55. @ApiImplicitParam(name = "page", value = "页数", dataType = "Integer", paramType = "query"),
  56. @ApiImplicitParam(name = "size", value = "条数", dataType = "Integer", paramType = "query"),
  57. })
  58. @PostMapping(value = "/list", name = "用户列表")
  59. @ResponseBody
  60. public Result list(@RequestParam(defaultValue = "[]") String where,
  61. @RequestParam(defaultValue = "0") Integer page,
  62. @RequestParam(defaultValue = "10") Integer size) {
  63. PageHelper.startPage(page, size);
  64. Condition c = new Condition(User.class);
  65. Example.Criteria criteria = c.createCriteria();
  66. buildWhere(where, criteria);
  67. List<User> list = userService.findByCondition(c);
  68. PageInfo pageInfo = new PageInfo<>(list);
  69. return ResultGenerator.genSuccessResult(pageInfo);
  70. }
  71. @ApiOperation(value = "用户添加角色", tags = {"账号管理"}, notes = "用户添加角色")
  72. @ApiImplicitParams({
  73. @ApiImplicitParam(name = "roles", value = "角色json", dataType = "String", paramType = "query"),
  74. @ApiImplicitParam(name = "userId", value = "用户id", dataType = "Long", paramType = "query"),
  75. })
  76. @PostMapping(value = "/add/role", name = "用户添加角色")
  77. @Caching(evict = {@CacheEvict(value = "role", key = "#userId"), @CacheEvict(value = "power", key = "#userId")})
  78. public Result addRole(String roles, Long userId) {
  79. List<Long> roleids = JSONUtils.json2list(roles, Long.class);
  80. return userService.addRole(roleids, userId);
  81. }
  82. @PostMapping(value = "/get/role", name = "获取用户角色")
  83. public Result getRole(@RequestParam Long userId) {
  84. List<Role> roles = userService.getRole(userId);
  85. return ResultGenerator.genSuccessResult(roles);
  86. }
  87. @ApiOperation(value = "获取登录用户信息", tags = {"账号管理"}, notes = "获取登录用户信息")
  88. @PostMapping(value = "get", name = "获取登录用户信息")
  89. public Result get(Authentication authentication) {
  90. AuthUser authUser = (AuthUser) authentication.getPrincipal();
  91. authUser.setPassword("");
  92. return ResultGenerator.genSuccessResult(authUser);
  93. }
  94. /**
  95. * 绑定微信
  96. *
  97. * @param openid
  98. * @param authentication
  99. * @return
  100. */
  101. @ApiOperation(value = "绑定微信", tags = {"账号管理"}, notes = "绑定微信")
  102. @ApiImplicitParams({
  103. @ApiImplicitParam(name = "openid", value = "openid", dataType = "String", paramType = "query"),
  104. })
  105. @PostMapping(value = "wx/bind", name = "绑定微信")
  106. public Result bindWx(@RequestParam String openid, Authentication authentication) {
  107. AuthUser authUser = (AuthUser) authentication.getPrincipal();
  108. User user = userService.findById(authUser.getId());
  109. if (user.getOpenid() != null) return ResultGenerator.genFailResult("用户以绑定微信");
  110. user.setOpenid(openid);
  111. userService.update(user);
  112. return ResultGenerator.genSuccessResult();
  113. }
  114. @ApiOperation(value = "根据openid刷新token", tags = {"账号管理"}, notes = "根据open刷新token")
  115. @ApiImplicitParams({
  116. @ApiImplicitParam(name = "openid", value = "openid", dataType = "String", paramType = "query"),
  117. })
  118. @PostMapping(value = "refresh/token", name = "根据open刷新token")
  119. public Result getTokenByOpenId(@RequestParam String openid) {
  120. User user = userService.findBy("openid", openid);
  121. if (user == null) return ResultGenerator.genFailResult("用户不存在");
  122. Map<String, Object> res = new HashMap<>();
  123. String jwtToken = jwtTokenUtil.generateToken(user.getUsername());
  124. res.put("token", jwtToken);
  125. return ResultGenerator.genSuccessResult(res);
  126. }
  127. @ApiOperation(value = "获取openid", tags = {"账号管理"}, notes = "获取openid")
  128. @ApiImplicitParams({
  129. @ApiImplicitParam(name = "appid", value = "appid", dataType = "String", paramType = "query"),
  130. @ApiImplicitParam(name = "secret", value = "secret", dataType = "String", paramType = "query"),
  131. @ApiImplicitParam(name = "jscode", value = "jscode", dataType = "String", paramType = "query"),
  132. })
  133. @PostMapping(value = "get/openid", name = "获取openId")
  134. public Result getOpenId(@RequestParam String appid,
  135. @RequestParam String secret,
  136. @RequestParam String jscode) {
  137. Map<String, Object> res = WxCommon.getOpenId(appid, secret, jscode);
  138. return ResultGenerator.genSuccessResult(res);
  139. }
  140. @ApiOperation(value = "修改密码", tags = {"账号管理"}, notes = "修改密码")
  141. @ApiImplicitParams({
  142. @ApiImplicitParam(name = "password", value = "新密码", dataType = "String", paramType = "query"),
  143. @ApiImplicitParam(name = "oldpassword", value = "旧密码", dataType = "String", paramType = "query"),
  144. })
  145. @PostMapping(value = "update/password", name = "修改密密")
  146. public Result password(String password,String oldpassword,Authentication authentication) {
  147. AuthUser authUser = (AuthUser) authentication.getPrincipal();
  148. return userService.updatePassword(password,oldpassword,authUser.getId());
  149. }
  150. }