From def38240262b4403377d4c16beac3ea048f1e658 Mon Sep 17 00:00:00 2001 From: huanghongfa <18228131219@163.com> Date: 星期日, 20 十二月 2020 13:25:39 +0800 Subject: [PATCH] 修改目录结构 --- springcloud_k8s_panzhihuazhihuishequ/common/src/main/java/com/panzhihua/common/controller/BaseController.java | 92 ++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 92 insertions(+), 0 deletions(-) diff --git a/springcloud_k8s_panzhihuazhihuishequ/common/src/main/java/com/panzhihua/common/controller/BaseController.java b/springcloud_k8s_panzhihuazhihuishequ/common/src/main/java/com/panzhihua/common/controller/BaseController.java new file mode 100644 index 0000000..778dbb3 --- /dev/null +++ b/springcloud_k8s_panzhihuazhihuishequ/common/src/main/java/com/panzhihua/common/controller/BaseController.java @@ -0,0 +1,92 @@ +package com.panzhihua.common.controller; + +import com.alibaba.fastjson.JSONObject; +import com.panzhihua.common.constants.Constants; +import com.panzhihua.common.constants.TokenConstant; +import com.panzhihua.common.constants.UserConstants; +import com.panzhihua.common.exceptions.UnAuthenticationException; +import com.panzhihua.common.model.vos.LoginUserInfoVO; +import com.panzhihua.common.utlis.AES; +import io.swagger.models.auth.In; +import lombok.SneakyThrows; +import org.springframework.util.ObjectUtils; +import org.springframework.web.context.request.RequestContextHolder; +import org.springframework.web.context.request.ServletRequestAttributes; +import sun.security.krb5.internal.crypto.Aes256; + +import javax.servlet.http.HttpServletRequest; + +/** + * @program: springcloud_k8s_panzhihuazhihuishequ + * @description: 基础controller + * @author: huang.hongfa weixin hhf9596 qq 959656820 + * @create: 2020-11-24 09:31 + **/ +public class BaseController { + /** + * 获取request对象 + */ + public HttpServletRequest getRequest() { + return ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest(); + } + + /** + * 获取登录对象信息 + * @return 对象userid + */ + public Long getUserId(){ + LoginUserInfoVO loginUserInfo = this.getLoginUserInfo(); + Long userId = loginUserInfo.getUserId(); + return userId; + } + + /** + * 获取登录对象所在社区id + * @return 社区id + */ + public Long getCommunityId(){ + LoginUserInfoVO loginUserInfo = this.getLoginUserInfo(); + Long communityId = loginUserInfo.getCommunityId(); + return communityId; + } + + /** + * 获取登录对象所在小区 + * @return 小区id + */ + public Long getAreaId(){ + LoginUserInfoVO loginUserInfo = this.getLoginUserInfo(); + Long areaId = loginUserInfo.getAreaId(); + return areaId; + } + + /** + * 获取登录token + * @return token + */ + public String getToken(){ + HttpServletRequest request = this.getRequest(); + String header = request.getHeader(TokenConstant.TOKEN_LOGOUT); + return header; + } + + /** + * 获取登录对象所有信息 + * @return 所有信息 + */ + @SneakyThrows + public LoginUserInfoVO getLoginUserInfo(){ + HttpServletRequest request = this.getRequest(); + String userInfo = request.getHeader(TokenConstant.TOKEN_USERINFO); + boolean empty = ObjectUtils.isEmpty(userInfo); + if (empty) { + throw new UnAuthenticationException("获取登录人信息失败"); + } + byte[] bytes = AES.parseHexStr2Byte(userInfo); + byte[] decrypt = AES.decrypt(bytes, Constants.AES_KEY); + userInfo=new String(decrypt); + LoginUserInfoVO loginUserInfoVO= JSONObject.parseObject(userInfo,LoginUserInfoVO.class); + return loginUserInfoVO; + } + +} -- Gitblit v1.7.1