Browse Source

1、权限验证添加

master
Aug 6 months ago
parent
commit
edc6eb3e07
3 changed files with 51 additions and 1 deletions
  1. +6
    -1
      jeecg-boot-base/jeecg-boot-base-core/src/main/java/org/jeecg/common/api/CommonAPI.java
  2. +29
    -0
      jeecg-boot-base/jeecg-boot-base-core/src/main/java/org/jeecg/config/shiro/ShiroRealm.java
  3. +16
    -0
      jeecg-boot-module-system/src/main/java/org/jeecg/modules/system/service/impl/SysBaseApiImpl.java

+ 6
- 1
jeecg-boot-base/jeecg-boot-base-core/src/main/java/org/jeecg/common/api/CommonAPI.java View File

@ -63,7 +63,12 @@ public interface CommonAPI {
* */
public HanHaiMember getUserByNameHanHaiAccount(String username);
/**
* 小程序验证 - 小程序openid验证
* @param username
* @return
* */
public HanHaiMember getUserByNameHanHaiXcxOpenId(String username);
/**
* 6字典表的 翻译


+ 29
- 0
jeecg-boot-base/jeecg-boot-base-core/src/main/java/org/jeecg/config/shiro/ShiroRealm.java View File

@ -191,6 +191,35 @@ public class ShiroRealm extends AuthorizingRealm {
}
/**
* 校验token的有效性
*
* @param token
*/
public HanHaiMember checkUserTokenIsEffectHanHaiOpenId(String token) throws AuthenticationException {
Result result = new Result();
// 解密获得username用于和数据库进行对比
String openid = JwtUtil.getUsername(token);
if (openid == null) {
throw new AuthenticationException("token非法无效!");
}
// 查询用户信息
log.debug("———校验token是否有效————checkUserTokenIsEffect——————— "+ token);
HanHaiMember user = commonApi.getUserByNameHanHaiXcxOpenId(openid);
if (user == null || user.getAppletOpenid() == null) {
throw new AuthenticationException("用户不存在!");
}
// // 判断用户状态
// if (user.getDeleteFlag().equals("Y")) {
// throw new AuthenticationException("账号已被注销,请联系管理员!");
// }
// 校验token是否超时失效 & 或者账号密码是否错误
if (!jwtTokenRefresh(token, openid, openid)) {
throw new JeecgBoot401Exception(CommonConstant.TOKEN_IS_INVALID_MSG);
}
return user;
}
/**
* JWTToken刷新生命周期 实现 用户在线操作不掉线功能


+ 16
- 0
jeecg-boot-module-system/src/main/java/org/jeecg/modules/system/service/impl/SysBaseApiImpl.java View File

@ -144,6 +144,22 @@ public class SysBaseApiImpl implements ISysBaseAPI {
return user;
}
/**
* 公共验证--根据账号查询验证用户信息-客户端
* @param username
* @return
* */
@Override
public HanHaiMember getUserByNameHanHaiXcxOpenId(String username){
if(oConvertUtils.isEmpty(username)) {
return null;
}
HanHaiMember user = hanHaiMemberService.lambdaQuery().eq(HanHaiMember::getAppletOpenid,username).one();
if(user==null) {
return null;
}
return user;
}
@Override
public String translateDictFromTable(String table, String text, String code, String key) {


Loading…
Cancel
Save