|
@@ -1,47 +1,38 @@
|
|
package com.zhentao.web.controller.system;
|
|
package com.zhentao.web.controller.system;
|
|
|
|
|
|
-import java.io.UnsupportedEncodingException;
|
|
|
|
-import java.security.InvalidAlgorithmParameterException;
|
|
|
|
-import java.security.InvalidKeyException;
|
|
|
|
-import java.security.NoSuchAlgorithmException;
|
|
|
|
-import java.security.spec.AlgorithmParameterSpec;
|
|
|
|
-import java.util.Arrays;
|
|
|
|
-import java.util.List;
|
|
|
|
-import java.util.Set;
|
|
|
|
-
|
|
|
|
import com.alibaba.fastjson2.JSON;
|
|
import com.alibaba.fastjson2.JSON;
|
|
import com.alibaba.fastjson2.JSONObject;
|
|
import com.alibaba.fastjson2.JSONObject;
|
|
import com.zhentao.common.config.WxAppConfig;
|
|
import com.zhentao.common.config.WxAppConfig;
|
|
-import com.zhentao.common.core.domain.model.WxLoginBody;
|
|
|
|
-import com.zhentao.common.utils.StringUtils;
|
|
|
|
-import com.zhentao.common.utils.sign.Base64;
|
|
|
|
-import org.slf4j.Logger;
|
|
|
|
-import org.slf4j.LoggerFactory;
|
|
|
|
-import org.springframework.beans.factory.annotation.Autowired;
|
|
|
|
-import org.springframework.security.core.session.SessionInformation;
|
|
|
|
-import org.springframework.web.bind.annotation.GetMapping;
|
|
|
|
-import org.springframework.web.bind.annotation.PostMapping;
|
|
|
|
-import org.springframework.web.bind.annotation.RequestBody;
|
|
|
|
-import org.springframework.web.bind.annotation.RestController;
|
|
|
|
import com.zhentao.common.constant.Constants;
|
|
import com.zhentao.common.constant.Constants;
|
|
import com.zhentao.common.core.domain.AjaxResult;
|
|
import com.zhentao.common.core.domain.AjaxResult;
|
|
import com.zhentao.common.core.domain.entity.SysMenu;
|
|
import com.zhentao.common.core.domain.entity.SysMenu;
|
|
import com.zhentao.common.core.domain.entity.SysUser;
|
|
import com.zhentao.common.core.domain.entity.SysUser;
|
|
import com.zhentao.common.core.domain.model.LoginBody;
|
|
import com.zhentao.common.core.domain.model.LoginBody;
|
|
import com.zhentao.common.core.domain.model.LoginUser;
|
|
import com.zhentao.common.core.domain.model.LoginUser;
|
|
|
|
+import com.zhentao.common.core.domain.model.WxLoginBody;
|
|
import com.zhentao.common.utils.SecurityUtils;
|
|
import com.zhentao.common.utils.SecurityUtils;
|
|
|
|
+import com.zhentao.common.utils.StringUtils;
|
|
|
|
+import com.zhentao.common.utils.sign.Base64;
|
|
import com.zhentao.framework.web.service.SysLoginService;
|
|
import com.zhentao.framework.web.service.SysLoginService;
|
|
import com.zhentao.framework.web.service.SysPermissionService;
|
|
import com.zhentao.framework.web.service.SysPermissionService;
|
|
import com.zhentao.framework.web.service.TokenService;
|
|
import com.zhentao.framework.web.service.TokenService;
|
|
import com.zhentao.system.service.ISysMenuService;
|
|
import com.zhentao.system.service.ISysMenuService;
|
|
|
|
+import org.slf4j.Logger;
|
|
|
|
+import org.slf4j.LoggerFactory;
|
|
|
|
+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.RequestBody;
|
|
|
|
+import org.springframework.web.bind.annotation.RestController;
|
|
import org.springframework.web.client.RestTemplate;
|
|
import org.springframework.web.client.RestTemplate;
|
|
|
|
|
|
-import javax.crypto.BadPaddingException;
|
|
|
|
import javax.crypto.Cipher;
|
|
import javax.crypto.Cipher;
|
|
-import javax.crypto.IllegalBlockSizeException;
|
|
|
|
-import javax.crypto.NoSuchPaddingException;
|
|
|
|
import javax.crypto.spec.IvParameterSpec;
|
|
import javax.crypto.spec.IvParameterSpec;
|
|
import javax.crypto.spec.SecretKeySpec;
|
|
import javax.crypto.spec.SecretKeySpec;
|
|
|
|
+import java.security.spec.AlgorithmParameterSpec;
|
|
|
|
+import java.util.Arrays;
|
|
|
|
+import java.util.List;
|
|
|
|
+import java.util.Set;
|
|
|
|
|
|
/**
|
|
/**
|
|
* 登录验证
|
|
* 登录验证
|
|
@@ -103,6 +94,7 @@ public class SysLoginController
|
|
// 如果解析成功, 获取token
|
|
// 如果解析成功, 获取token
|
|
String token = loginService.wxLogin(decryptResult);
|
|
String token = loginService.wxLogin(decryptResult);
|
|
AjaxResult ajax = AjaxResult.success();
|
|
AjaxResult ajax = AjaxResult.success();
|
|
|
|
+ ajax.put(Constants.TOKEN, token);
|
|
return ajax;
|
|
return ajax;
|
|
}else{
|
|
}else{
|
|
return AjaxResult.error("微信登录失败");
|
|
return AjaxResult.error("微信登录失败");
|
|
@@ -185,12 +177,15 @@ public class SysLoginController
|
|
public AjaxResult getInfo()
|
|
public AjaxResult getInfo()
|
|
{
|
|
{
|
|
LoginUser loginUser = SecurityUtils.getLoginUser();
|
|
LoginUser loginUser = SecurityUtils.getLoginUser();
|
|
|
|
+ if (loginUser == null) {
|
|
|
|
+ return AjaxResult.error("未获取到登录用户信息");
|
|
|
|
+ }
|
|
SysUser user = loginUser.getUser();
|
|
SysUser user = loginUser.getUser();
|
|
// 角色集合
|
|
// 角色集合
|
|
Set<String> roles = permissionService.getRolePermission(user);
|
|
Set<String> roles = permissionService.getRolePermission(user);
|
|
// 权限集合
|
|
// 权限集合
|
|
Set<String> permissions = permissionService.getMenuPermission(user);
|
|
Set<String> permissions = permissionService.getMenuPermission(user);
|
|
- if (!loginUser.getPermissions().equals(permissions))
|
|
|
|
|
|
+ if (loginUser.getPermissions() != null && !loginUser.getPermissions().equals(permissions))
|
|
{
|
|
{
|
|
loginUser.setPermissions(permissions);
|
|
loginUser.setPermissions(permissions);
|
|
tokenService.refreshToken(loginUser);
|
|
tokenService.refreshToken(loginUser);
|