From 5b1f8540b5843578a80e4aa34e371f1a5b40f31e Mon Sep 17 00:00:00 2001
From: lidongdong <1459917685@qq.com>
Date: 星期四, 17 八月 2023 16:53:01 +0800
Subject: [PATCH] 修改最美志愿者编辑报错id为空
---
springcloud_k8s_panzhihuazhihuishequ/common/src/main/java/com/panzhihua/common/controller/BaseController.java | 176 +++++++++++++++++++++++++++++++++++++++++++++++++++++-----
1 files changed, 159 insertions(+), 17 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
index 24c9c17..963b4e3 100644
--- 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
@@ -1,13 +1,26 @@
package com.panzhihua.common.controller;
-import com.panzhihua.common.constants.TokenConstant;
-import com.panzhihua.common.constants.UserConstants;
-import com.panzhihua.common.model.vos.LoginUserInfoVO;
+import javax.servlet.http.HttpServletRequest;
+
+import com.panzhihua.common.model.vos.community.ComActVO;
+import com.panzhihua.common.utlis.StringUtils;
import org.springframework.util.ObjectUtils;
import org.springframework.web.context.request.RequestContextHolder;
import org.springframework.web.context.request.ServletRequestAttributes;
-import javax.servlet.http.HttpServletRequest;
+import com.alibaba.fastjson.JSONObject;
+import com.panzhihua.common.constants.Constants;
+import com.panzhihua.common.constants.TokenConstant;
+import com.panzhihua.common.exceptions.ServiceException;
+import com.panzhihua.common.exceptions.UnAuthenticationException;
+import com.panzhihua.common.model.vos.LoginUserInfoVO;
+import com.panzhihua.common.utlis.AES;
+
+import lombok.SneakyThrows;
+import lombok.extern.slf4j.Slf4j;
+
+import static java.util.Objects.isNull;
+import static org.apache.commons.lang3.StringUtils.isBlank;
/**
* @program: springcloud_k8s_panzhihuazhihuishequ
@@ -15,39 +28,168 @@
* @author: huang.hongfa weixin hhf9596 qq 959656820
* @create: 2020-11-24 09:31
**/
+@Slf4j
public class BaseController {
+ public static void main(String[] args) {
+ byte[] bytes = AES.parseHexStr2Byte(
+ "5730CB290AD203B32D2FA4347CD54A50A684E16D2C7A4544CF352D54D8A763BA6652C323B13BEEE682A5095B8BCC76842225A914253CE84AFB6B58A9D1BE30A7992786E151A933FDEC6EBDCD1928CA68927047770F296F7541268149B34FDFCEF1340CF2266A041484744CB45B216EE8B4D96E243098F9CB3F661ACA7AF356C422BFE9A009FA478DF606A71DA7DBD776527E5120C3F13281BA8FC5587BACD5E403EE069762B5CF060BFA3CF4FD3417F5653CC178D2CA117284D85F442C0FAB076DB6F6D873B5363FAB93EBA9284CC87A5E97243EF4DC73F1ADA57BD9E9AAB2E4972AC3A4615B2DF6F9062BC04428D1B84B6C892A306F191B1D9DDBBB201D2767CE928020489AFC6BCFDC8A74F8C95080F74B4EC64AD1A6354B17A156B95AA9467C7461BD3C3F15F8F65BD7F3272184435D77003738B5B942EEA9603CFF249764718732595EC44DE4ED1BB763F9C88BAFACF5540E689FE84A4702E31D3D1D05BAC25C10F8E0C3948C777478537397BCB67D37066385DFCBDE3F4A53D6BA14481DBCB07E8452ACD2790A76669A9DE6D7080C8CFD9FB774035FCC3AC1C436581144969B7150318024A2E893FE926654E002097EB4735E49F3A9698A405969888A7D88A55A0FA60318C4A1E2D243BEE6D438");
+ byte[] decrypt = AES.decrypt(bytes, Constants.AES_KEY);
+ System.out.println(decrypt);
+ String s = new String(decrypt);
+ System.out.println(s);
+ }
+
/**
* 获取request对象
*/
public HttpServletRequest getRequest() {
- return ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest();
+ return ((ServletRequestAttributes)RequestContextHolder.getRequestAttributes()).getRequest();
}
/**
* 获取登录对象信息
- * @return
+ *
+ * @return 对象userid
*/
- public Long getUserId(){
- HttpServletRequest request = this.getRequest();
- Long header = Long.valueOf(request.getHeader(UserConstants.USER_ID));
- boolean empty = ObjectUtils.isEmpty(header);
- if (empty) {
- return null;
+ 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();
+// if (null == communityId) {
+// throw new ServiceException("用户未绑定社区");
+// }
+ return communityId;
+ }
+
+ /**
+ * 获取登录对象所在社区名称
+ *
+ * @return 社区名称
+ */
+ public String getCommunityName() {
+ LoginUserInfoVO loginUserInfo = this.getLoginUserInfo();
+ Long communityId = loginUserInfo.getCommunityId();
+ if (null == communityId || 0 == communityId) {
+ throw new ServiceException("用户未绑定社区");
}
- return header;
+ String communityName = loginUserInfo.getCommunityName();
+ return communityName;
+ }
+
+ /**
+ * 获取登录对象所在小区
+ *
+ * @return 小区id
+ */
+ public Long getAreaId() {
+ LoginUserInfoVO loginUserInfo = this.getLoginUserInfo();
+ Long areaId = loginUserInfo.getAreaId();
+ if (null == areaId) {
+ throw new ServiceException("用户未绑定小区");
+ }
+ return areaId;
}
/**
- * 获取登录token
+ * 获取登录对象所在区域编码
+ *
* @return
*/
- public String getToken(){
+ public String getAreaCode() {
+ String appid = this.getRequest().getHeader("appid");
+ if(StringUtils.isNotEmpty(appid)){
+ if(appid.equals("wx08932ba29546ff82")){
+ return "510411";
+ }
+ else if(appid.equals("wx50d8c395af50481b")){
+ return "510402";
+ }
+ else {
+ return "510423";
+ }
+ } else {
+ LoginUserInfoVO loginUserInfoVO=this.getLoginUserInfo();
+ ComActVO comActVO=loginUserInfoVO.getComActVO();
+ if(isNull(comActVO) || isBlank(comActVO.getAreaCode())){
+ return "510423";
+ }
+ return comActVO.getAreaCode();
+ }
+ }
+
+
+ /**
+ * 获取登录token
+ *
+ * @return token
+ */
+ public String getToken() {
HttpServletRequest request = this.getRequest();
String header = request.getHeader(TokenConstant.TOKEN_LOGOUT);
- boolean empty = ObjectUtils.isEmpty(header);
+ return header;
+ }
+
+ public String getAppId(){
+ String appid = this.getRequest().getHeader("appid");
+ if(StringUtils.isEmpty(appid)){
+ return "wx0cef797390444b75";
+ }
+ return appid;
+ }
+
+ public String getAppSecret(){
+ LoginUserInfoVO loginUserInfo = this.getLoginUserInfo();
+ return loginUserInfo.getAppSecret();
+ }
+ /**
+ * 获取登录对象所有信息
+ *
+ * @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("获取登录人信息失败");
+ }
+ // log.info("userInfo【{}】",userInfo);
+ byte[] bytes = AES.parseHexStr2Byte(userInfo);
+ // log.info("bytes【{}】",bytes);
+ byte[] decrypt = AES.decrypt(bytes, Constants.AES_KEY);
+ // log.info("decrypt【{}】",decrypt);
+ userInfo = new String(decrypt);
+ LoginUserInfoVO loginUserInfoVO = JSONObject.parseObject(userInfo, LoginUserInfoVO.class);
+ return loginUserInfoVO;
+ }
+
+ @SneakyThrows
+ public LoginUserInfoVO getLoginUserInfoSureNoLogin() {
+ HttpServletRequest request = this.getRequest();
+ String userInfo = request.getHeader(TokenConstant.TOKEN_USERINFO);
+ boolean empty = ObjectUtils.isEmpty(userInfo);
if (empty) {
return null;
+ // throw new UnAuthenticationException("获取登录人信息失败");
}
- return header;
+ // log.info("userInfo【{}】",userInfo);
+ byte[] bytes = AES.parseHexStr2Byte(userInfo);
+ // log.info("bytes【{}】",bytes);
+ byte[] decrypt = AES.decrypt(bytes, Constants.AES_KEY);
+ // log.info("decrypt【{}】",decrypt);
+ userInfo = new String(decrypt);
+ LoginUserInfoVO loginUserInfoVO = JSONObject.parseObject(userInfo, LoginUserInfoVO.class);
+ return loginUserInfoVO;
}
}
--
Gitblit v1.7.1