package com.ruoyi.web.controller.system; 
 | 
  
 | 
import java.io.IOException; 
 | 
  
 | 
import com.ruoyi.common.core.domain.entity.UpdateUserPWD; 
 | 
import io.swagger.annotations.ApiOperation; 
 | 
import org.springframework.beans.factory.annotation.Autowired; 
 | 
import org.springframework.web.bind.annotation.GetMapping; 
 | 
import org.springframework.web.bind.annotation.PostMapping; 
 | 
import org.springframework.web.bind.annotation.PutMapping; 
 | 
import org.springframework.web.bind.annotation.RequestBody; 
 | 
import org.springframework.web.bind.annotation.RequestMapping; 
 | 
import org.springframework.web.bind.annotation.RequestParam; 
 | 
import org.springframework.web.bind.annotation.RestController; 
 | 
import org.springframework.web.multipart.MultipartFile; 
 | 
import com.ruoyi.common.annotation.Log; 
 | 
import com.ruoyi.common.config.RuoYiConfig; 
 | 
import com.ruoyi.common.constant.UserConstants; 
 | 
import com.ruoyi.common.core.controller.BaseController; 
 | 
import com.ruoyi.common.core.domain.AjaxResult; 
 | 
import com.ruoyi.common.core.domain.entity.SysUser; 
 | 
import com.ruoyi.common.core.domain.model.LoginUser; 
 | 
import com.ruoyi.common.enums.BusinessType; 
 | 
import com.ruoyi.common.utils.SecurityUtils; 
 | 
import com.ruoyi.common.utils.StringUtils; 
 | 
import com.ruoyi.common.utils.file.FileUploadUtils; 
 | 
import com.ruoyi.framework.web.service.TokenService; 
 | 
import com.ruoyi.system.service.ISysUserService; 
 | 
  
 | 
/** 
 | 
 * 个人信息 业务处理 
 | 
 *  
 | 
 * @author ruoyi 
 | 
 */ 
 | 
@RestController 
 | 
@RequestMapping("/system/user/profile") 
 | 
public class SysProfileController extends BaseController 
 | 
{ 
 | 
    @Autowired 
 | 
    private ISysUserService userService; 
 | 
  
 | 
    @Autowired 
 | 
    private TokenService tokenService; 
 | 
  
 | 
    /** 
 | 
     * 个人信息 
 | 
     */ 
 | 
    @ApiOperation("个人信息") 
 | 
    @Log(title = "个人信息", businessType = BusinessType.OTHER) 
 | 
    @GetMapping 
 | 
    public AjaxResult profile() 
 | 
    { 
 | 
        LoginUser loginUser = getLoginUser(); 
 | 
        SysUser user = loginUser.getUser(); 
 | 
        AjaxResult ajax = AjaxResult.success(user); 
 | 
        ajax.put("roleGroup", userService.selectUserRoleGroup(loginUser.getUsername())); 
 | 
        ajax.put("postGroup", userService.selectUserPostGroup(loginUser.getUsername())); 
 | 
        return ajax; 
 | 
    } 
 | 
  
 | 
    /** 
 | 
     * 修改用户 
 | 
     */ 
 | 
    @Log(title = "个人信息", businessType = BusinessType.UPDATE) 
 | 
    @PostMapping("/updateProfile") 
 | 
    public AjaxResult updateProfile(@RequestBody SysUser user) 
 | 
    { 
 | 
        if (StringUtils.isNotEmpty(user.getPhonenumber()) 
 | 
                && UserConstants.NOT_UNIQUE.equals(userService.checkPhoneUnique(user))) 
 | 
        { 
 | 
            return AjaxResult.error("修改用户'" + user.getUserName() + "'失败,手机号码已存在"); 
 | 
        } 
 | 
        if (StringUtils.isNotEmpty(user.getEmail()) 
 | 
                && UserConstants.NOT_UNIQUE.equals(userService.checkEmailUnique(user))) 
 | 
        { 
 | 
            return AjaxResult.error("修改用户'" + user.getUserName() + "'失败,邮箱账号已存在"); 
 | 
        } 
 | 
        LoginUser loginUser = getLoginUser(); 
 | 
        SysUser sysUser = loginUser.getUser(); 
 | 
        user.setUserId(sysUser.getUserId()); 
 | 
        user.setPassword(null); 
 | 
        if (userService.updateUserProfile(user) > 0) 
 | 
        { 
 | 
            // 更新缓存用户信息 
 | 
            sysUser.setNickName(user.getNickName()); 
 | 
            sysUser.setPhonenumber(user.getPhonenumber()); 
 | 
            sysUser.setEmail(user.getEmail()); 
 | 
            sysUser.setSex(user.getSex()); 
 | 
            tokenService.setLoginUser(loginUser); 
 | 
            return AjaxResult.success(); 
 | 
        } 
 | 
        return AjaxResult.error("修改个人信息异常,请联系管理员"); 
 | 
    } 
 | 
  
 | 
    /** 
 | 
     * 重置密码 
 | 
     */ 
 | 
    @Log(title = "个人信息", businessType = BusinessType.UPDATE) 
 | 
    @PostMapping("/updatePwd") 
 | 
    public AjaxResult updatePwd(@RequestBody UpdateUserPWD updateUserPWD) 
 | 
    { 
 | 
        LoginUser loginUser = getLoginUser(); 
 | 
        String userName = loginUser.getUsername(); 
 | 
        String password = loginUser.getPassword(); 
 | 
        if (!SecurityUtils.matchesPassword(updateUserPWD.getOldPassword(), password)) 
 | 
        { 
 | 
            return AjaxResult.error("修改密码失败,旧密码错误"); 
 | 
        } 
 | 
        if (SecurityUtils.matchesPassword(updateUserPWD.getNewPassword(), password)) 
 | 
        { 
 | 
            return AjaxResult.error("新密码不能与旧密码相同"); 
 | 
        } 
 | 
        if(!checkPasswordRule(updateUserPWD.getNewPassword())){ 
 | 
            return AjaxResult.error("密码格式: 大小写字母、数字、特殊字符中的至少三种(长度大于等于8位)"); 
 | 
        } 
 | 
        if (userService.resetUserPwd(userName, SecurityUtils.encryptPassword(updateUserPWD.getNewPassword())) > 0 && checkPasswordRule(updateUserPWD.getNewPassword())) 
 | 
        { 
 | 
            // 更新缓存用户密码 
 | 
            loginUser.getUser().setPassword(SecurityUtils.encryptPassword(updateUserPWD.getNewPassword())); 
 | 
            tokenService.setLoginUser(loginUser); 
 | 
            return AjaxResult.success(); 
 | 
        } 
 | 
        return AjaxResult.error("修改密码异常,请联系管理员"); 
 | 
    } 
 | 
  
 | 
    public static final String REG_NUMBER = ".*\\d+.*"; 
 | 
    //小写字母 
 | 
    public static final String REG_UPPERCASE = ".*[A-Z]+.*"; 
 | 
    //大写字母 
 | 
    public static final String REG_LOWERCASE = ".*[a-z]+.*"; 
 | 
    //特殊符号 
 | 
    public static final String REG_SYMBOL = ".*[~!@#$%^&*()_+|<>,.?/:;'\\[\\]{}\"]+.*"; 
 | 
    public static boolean checkPasswordRule(String password) { 
 | 
        //密码为空或者长度小于8位则返回false 
 | 
        if (password == null || password.length() < 8) return false; 
 | 
        int i = 0; 
 | 
        if (password.matches(REG_NUMBER)) i++; 
 | 
        if (password.matches(REG_LOWERCASE)) i++; 
 | 
        if (password.matches(REG_UPPERCASE)) i++; 
 | 
        if (password.matches(REG_SYMBOL)) i++; 
 | 
        if (i < 3) return false; 
 | 
        return true; 
 | 
    } 
 | 
  
 | 
    /** 
 | 
     * 头像上传 
 | 
     */ 
 | 
    @Log(title = "用户头像", businessType = BusinessType.UPDATE) 
 | 
    @PostMapping("/avatar") 
 | 
    public AjaxResult avatar(@RequestParam("avatarfile") MultipartFile file) throws IOException 
 | 
    { 
 | 
        if (!file.isEmpty()) 
 | 
        { 
 | 
            LoginUser loginUser = getLoginUser(); 
 | 
            String avatar = FileUploadUtils.upload(RuoYiConfig.getAvatarPath(), file); 
 | 
            if (userService.updateUserAvatar(loginUser.getUsername(), avatar)) 
 | 
            { 
 | 
                AjaxResult ajax = AjaxResult.success(); 
 | 
                ajax.put("imgUrl", avatar); 
 | 
                // 更新缓存用户头像 
 | 
                loginUser.getUser().setAvatar(avatar); 
 | 
                tokenService.setLoginUser(loginUser); 
 | 
                return ajax; 
 | 
            } 
 | 
        } 
 | 
        return AjaxResult.error("上传图片异常,请联系管理员"); 
 | 
    } 
 | 
} 
 |