Commit 3551ee37 by 陈健智

接口访问日志记录

parent 79a94238
package com.zhiwei.brandkbs2.aop;
import com.zhiwei.brandkbs2.auth.UserThreadLocal;
import com.zhiwei.brandkbs2.common.GenericAttribute;
import com.zhiwei.brandkbs2.dao.BehaviorDao;
import com.zhiwei.brandkbs2.pojo.Behavior;
import com.zhiwei.brandkbs2.service.UserService;
import com.zhiwei.brandkbs2.util.Tools;
import com.zhiwei.middleware.auth.util.JwtUtil;
import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.aspectj.lang.reflect.MethodSignature;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;
import org.springframework.web.context.request.*;
import org.springframework.web.multipart.MultipartFile;
import org.springframework.web.servlet.HandlerMapping;
import javax.annotation.Resource;
import javax.servlet.ServletRequest;
import javax.servlet.http.HttpServletRequest;
import java.net.InetAddress;
import java.net.UnknownHostException;
import java.util.*;
import static java.util.Objects.nonNull;
/**
* @author cjz
* @ClassName AopLogRecord
* @Description 接口访问日志记录
* @date 2022-09-13 15:25
*/
@Aspect
@Component
public class AopLogRecord {
@Value("${jwt.key}")
private String jwtKey;
@Resource(name = "userServiceImpl")
private UserService userService;
@Resource(name = "behaviorDao")
private BehaviorDao behaviorDao;
private static final List<String> URL_PATTERNS = Arrays.asList("/getNewAll", "/getNew", "/schedule");
@Before("execution(public * com..controller..*Controller.*(..)) && !execution(* com..controller..BaseController.*(..))")
private void beforeLog(JoinPoint joinPoint) throws UnknownHostException {
long now = System.currentTimeMillis();
// RequestContextHolder是持有上下文的Request容器
ServletRequestAttributes requestAttributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
// 获取request对象
HttpServletRequest request = Objects.requireNonNull(requestAttributes).getRequest();
// webRequest拿路径的uri和request拿的uri有区别
NativeWebRequest webRequest = new ServletWebRequest(request);
Object webRequestAttribute = webRequest.getAttribute(HandlerMapping.BEST_MATCHING_PATTERN_ATTRIBUTE, RequestAttributes.SCOPE_REQUEST);
if (filterUrl(webRequestAttribute)) {
// controller接口信息
String httpMethod = request.getMethod();
String uri = request.getRequestURI();
String methodName = joinPoint.getSignature().getName();
if (!(Tools.isNullOrUndefined(request.getHeader(jwtKey)) || Tools.isNullOrUndefined(request.getHeader("pid")))) {
// 用户信息
String userId = JwtUtil.unsign(request.getHeader(jwtKey), Map.class).get(GenericAttribute.USER_ID).toString();
String projectId = request.getHeader("pid");
String nickName = userService.queryUserInfo(userId, projectId).getNickname();
// 请求地址和服务器地址
String severAddress = InetAddress.getLocalHost().getHostAddress();
String ipAddress = Tools.getIpAddress(request);
// 接口传参信息
List<Map<String, Object>> requestArguments = getRequestArguments(joinPoint);
Behavior behavior = Behavior.createBehaviorNew(userId, nickName, projectId, uri, methodName, httpMethod, requestArguments, now, now, severAddress, ipAddress);
String collectionName = behaviorDao.generateCollectionName();
behaviorDao.insertOneWithoutId(behavior, collectionName);
}
}
}
private List<Map<String, Object>> getRequestArguments(JoinPoint joinPoint) {
List<Map<String, Object>> arguments = new ArrayList<>();
// 获取参数名
MethodSignature methodSignature = (MethodSignature) joinPoint.getSignature();
String[] parameterNames = methodSignature.getParameterNames();
// 获取参数值
for (int i = 0; i < joinPoint.getArgs().length; i++) {
// 过滤HttpServletRequest参数
if (joinPoint.getArgs()[i] instanceof ServletRequest) {
continue;
}
// formdata文件类型判断
if (joinPoint.getArgs()[i] instanceof MultipartFile) {
Map<String, Object> fileMap = new HashMap<>();
fileMap.put("name", parameterNames[i]);
MultipartFile file = (MultipartFile) joinPoint.getArgs()[i];
// 文件名
fileMap.put("value", file.getOriginalFilename());
arguments.add(fileMap);
continue;
}
// 参数pathId、param、body
Map<String, Object> parameterMap = new HashMap<>();
parameterMap.put("name", parameterNames[i]);
parameterMap.put("value", String.valueOf(joinPoint.getArgs()[i]));
arguments.add(parameterMap);
}
return arguments;
}
/**
* url过滤
* @param attribute url
* @return
*/
private boolean filterUrl(Object attribute){
if (!nonNull(attribute)) {
return false;
}
String requestURI = String.valueOf(attribute);
for (String urlPattern : URL_PATTERNS) {
if (requestURI.contains(urlPattern)) {
return false;
}
}
return true;
}
}
...@@ -178,7 +178,7 @@ public class ArticleController extends BaseController { ...@@ -178,7 +178,7 @@ public class ArticleController extends BaseController {
requestMap.add("projectId", projectService.getProjectByContendId(UserThreadLocal.getProjectId(), contendId).getBrandLinkedGroupId()); requestMap.add("projectId", projectService.getProjectByContendId(UserThreadLocal.getProjectId(), contendId).getBrandLinkedGroupId());
HttpEntity<MultiValueMap<String, Object>> requestEntity = new HttpEntity<>(requestMap, getHeadersForm()); HttpEntity<MultiValueMap<String, Object>> requestEntity = new HttpEntity<>(requestMap, getHeadersForm());
HttpEntity<JSONObject> entity = restTemplate.exchange(yuqingInterface + "/upload/form", HttpMethod.POST, requestEntity, JSONObject.class); HttpEntity<JSONObject> entity = restTemplate.exchange(yuqingInterface + "/upload/form", HttpMethod.POST, requestEntity, JSONObject.class);
behaviorService.pushBehavior(OPERATION, "上传表格", request); behaviorService.pushBehaviorOld(OPERATION, "上传表格", request);
return ResponseResult.convertFromYuQingInterface(entity.getBody(), null); return ResponseResult.convertFromYuQingInterface(entity.getBody(), null);
} catch (Exception e) { } catch (Exception e) {
log.error("稿件上传-上传表格异常", e); log.error("稿件上传-上传表格异常", e);
......
...@@ -53,7 +53,7 @@ public class CustomTagController extends BaseController { ...@@ -53,7 +53,7 @@ public class CustomTagController extends BaseController {
public ResponseResult addCustomTag(@ApiIgnore @RequestBody JSONObject json) { public ResponseResult addCustomTag(@ApiIgnore @RequestBody JSONObject json) {
customTagService.addCustomTag(json.getString("tagName"), parseArray(json.getString("sonTagNames"), String.class)); customTagService.addCustomTag(json.getString("tagName"), parseArray(json.getString("sonTagNames"), String.class));
// 添加用户行为 // 添加用户行为
behaviorService.pushBehavior(OPERATION, "添加自定义标签", request); behaviorService.pushBehaviorOld(OPERATION, "添加自定义标签", request);
return ResponseResult.success(); return ResponseResult.success();
} }
...@@ -66,7 +66,7 @@ public class CustomTagController extends BaseController { ...@@ -66,7 +66,7 @@ public class CustomTagController extends BaseController {
String tagId = json.getString("tagId"); String tagId = json.getString("tagId");
customTagService.updateCustomTag(tagName, sonTagNames, tagId); customTagService.updateCustomTag(tagName, sonTagNames, tagId);
// 添加用户行为 // 添加用户行为
behaviorService.pushBehavior(OPERATION, "修改自定义标签", request); behaviorService.pushBehaviorOld(OPERATION, "修改自定义标签", request);
return ResponseResult.success(); return ResponseResult.success();
} }
...@@ -77,7 +77,7 @@ public class CustomTagController extends BaseController { ...@@ -77,7 +77,7 @@ public class CustomTagController extends BaseController {
public ResponseResult deleteCustomTag(@PathVariable String tagId) { public ResponseResult deleteCustomTag(@PathVariable String tagId) {
customTagService.deleteCustomTagByTagId(tagId); customTagService.deleteCustomTagByTagId(tagId);
// 添加用户行为 // 添加用户行为
behaviorService.pushBehavior(OPERATION, "删除自定义标签", request); behaviorService.pushBehaviorOld(OPERATION, "删除自定义标签", request);
return ResponseResult.success(); return ResponseResult.success();
} }
} }
...@@ -108,7 +108,7 @@ public class EventController extends BaseController { ...@@ -108,7 +108,7 @@ public class EventController extends BaseController {
@PutMapping("/update") @PutMapping("/update")
public ResponseResult updateEvent(@RequestBody EventVO eventVO) { public ResponseResult updateEvent(@RequestBody EventVO eventVO) {
eventService.updateEvent(eventVO); eventService.updateEvent(eventVO);
behaviorService.pushBehavior(OPERATION, "修改事件信息:" + eventVO.getId(), request); behaviorService.pushBehaviorOld(OPERATION, "修改事件信息:" + eventVO.getId(), request);
return ResponseResult.success(); return ResponseResult.success();
} }
...@@ -116,7 +116,7 @@ public class EventController extends BaseController { ...@@ -116,7 +116,7 @@ public class EventController extends BaseController {
@PutMapping("/updateFirst") @PutMapping("/updateFirst")
public ResponseResult updateEventFirst(@RequestBody EventDataDTO eventDataDTO) { public ResponseResult updateEventFirst(@RequestBody EventDataDTO eventDataDTO) {
eventService.updateEventFirst(eventDataDTO); eventService.updateEventFirst(eventDataDTO);
behaviorService.pushBehavior(OPERATION, "修改事件首发信息:" + eventDataDTO.getEventId(), request); behaviorService.pushBehaviorOld(OPERATION, "修改事件首发信息:" + eventDataDTO.getEventId(), request);
return ResponseResult.success(); return ResponseResult.success();
} }
...@@ -125,7 +125,7 @@ public class EventController extends BaseController { ...@@ -125,7 +125,7 @@ public class EventController extends BaseController {
@PostMapping("/analyze") @PostMapping("/analyze")
public ResponseResult analysisEvents(@RequestBody JSONObject info) { public ResponseResult analysisEvents(@RequestBody JSONObject info) {
eventService.analysisEvents(info.getJSONArray("eventIds").toJavaList(String.class)); eventService.analysisEvents(info.getJSONArray("eventIds").toJavaList(String.class));
behaviorService.pushBehavior(OPERATION, "批量更新事件", request); behaviorService.pushBehaviorOld(OPERATION, "批量更新事件", request);
return ResponseResult.success(); return ResponseResult.success();
} }
...@@ -134,7 +134,7 @@ public class EventController extends BaseController { ...@@ -134,7 +134,7 @@ public class EventController extends BaseController {
@PutMapping("/end/{eventId}") @PutMapping("/end/{eventId}")
public ResponseResult endEvent(@PathVariable("eventId") String eventId) { public ResponseResult endEvent(@PathVariable("eventId") String eventId) {
eventService.endEvent(eventId); eventService.endEvent(eventId);
behaviorService.pushBehavior(OPERATION, "结束事件:" + eventId, request); behaviorService.pushBehaviorOld(OPERATION, "结束事件:" + eventId, request);
return ResponseResult.success(); return ResponseResult.success();
} }
...@@ -143,7 +143,7 @@ public class EventController extends BaseController { ...@@ -143,7 +143,7 @@ public class EventController extends BaseController {
@DeleteMapping("/delete/{eventId}") @DeleteMapping("/delete/{eventId}")
public ResponseResult deleteEvent(@PathVariable("eventId") String eventId) { public ResponseResult deleteEvent(@PathVariable("eventId") String eventId) {
String title = eventService.deleteEvent(eventId); String title = eventService.deleteEvent(eventId);
behaviorService.pushBehavior(OPERATION, "删除事件:" + title, request); behaviorService.pushBehaviorOld(OPERATION, "删除事件:" + title, request);
return ResponseResult.success(); return ResponseResult.success();
} }
...@@ -154,7 +154,7 @@ public class EventController extends BaseController { ...@@ -154,7 +154,7 @@ public class EventController extends BaseController {
String id = info.getString("id"); String id = info.getString("id");
String eventId = info.getString("eventId"); String eventId = info.getString("eventId");
String title = eventService.deleteEventData(id, eventId); String title = eventService.deleteEventData(id, eventId);
behaviorService.pushBehavior(OPERATION, "删除事件单条数据,eventId:" + eventId + ",数据id:" + id + ",事件标题:" + title, request); behaviorService.pushBehaviorOld(OPERATION, "删除事件单条数据,eventId:" + eventId + ",数据id:" + id + ",事件标题:" + title, request);
return ResponseResult.success(); return ResponseResult.success();
} }
...@@ -225,7 +225,7 @@ public class EventController extends BaseController { ...@@ -225,7 +225,7 @@ public class EventController extends BaseController {
String contendId = null == info.getString("contendId") ? "0" : info.getString("contendId"); String contendId = null == info.getString("contendId") ? "0" : info.getString("contendId");
List<YqEventDTO> yqEventList = info.getJSONArray("list").toJavaList(YqEventDTO.class); List<YqEventDTO> yqEventList = info.getJSONArray("list").toJavaList(YqEventDTO.class);
eventService.addYqEvents(contendId, yqEventList); eventService.addYqEvents(contendId, yqEventList);
behaviorService.pushBehavior(OPERATION, "批量导入舆情事件数据", request); behaviorService.pushBehaviorOld(OPERATION, "批量导入舆情事件数据", request);
return ResponseResult.success(); return ResponseResult.success();
} }
...@@ -233,7 +233,7 @@ public class EventController extends BaseController { ...@@ -233,7 +233,7 @@ public class EventController extends BaseController {
@PutMapping("/upload/yqAll") @PutMapping("/upload/yqAll")
public ResponseResult addEventAllByYq(@RequestBody YqEventSearchVO yqEventSearchVO) { public ResponseResult addEventAllByYq(@RequestBody YqEventSearchVO yqEventSearchVO) {
eventService.addYqEventAll(yqEventSearchVO); eventService.addYqEventAll(yqEventSearchVO);
behaviorService.pushBehavior(OPERATION, "全部导入舆情事件数据", request); behaviorService.pushBehaviorOld(OPERATION, "全部导入舆情事件数据", request);
return ResponseResult.success(); return ResponseResult.success();
} }
...@@ -244,7 +244,7 @@ public class EventController extends BaseController { ...@@ -244,7 +244,7 @@ public class EventController extends BaseController {
@Auth(role = RoleEnum.SUPER_ADMIN) @Auth(role = RoleEnum.SUPER_ADMIN)
public ResponseResult addEventsByFile(@RequestParam(value = "contendId", defaultValue = "0") String contendId, @RequestParam("fileUrl") String fileUrl) { public ResponseResult addEventsByFile(@RequestParam(value = "contendId", defaultValue = "0") String contendId, @RequestParam("fileUrl") String fileUrl) {
eventService.addFileEvents(contendId, fileUrl); eventService.addFileEvents(contendId, fileUrl);
behaviorService.pushBehavior(OPERATION, "文件上传事件", request); behaviorService.pushBehaviorOld(OPERATION, "文件上传事件", request);
return ResponseResult.success(); return ResponseResult.success();
} }
...@@ -254,7 +254,7 @@ public class EventController extends BaseController { ...@@ -254,7 +254,7 @@ public class EventController extends BaseController {
@PostMapping(value = "/data/upload", headers = "content-type=multipart/form-data") @PostMapping(value = "/data/upload", headers = "content-type=multipart/form-data")
public ResponseResult uploadEventDatas(@RequestParam(value = "contendId", defaultValue = "0") String contendId, @RequestParam("file") MultipartFile file) { public ResponseResult uploadEventDatas(@RequestParam(value = "contendId", defaultValue = "0") String contendId, @RequestParam("file") MultipartFile file) {
eventService.uploadEventDatas(contendId, file); eventService.uploadEventDatas(contendId, file);
behaviorService.pushBehavior(OPERATION, "事件数据上传", request); behaviorService.pushBehaviorOld(OPERATION, "事件数据上传", request);
return ResponseResult.success(); return ResponseResult.success();
} }
......
...@@ -76,7 +76,7 @@ public class ProjectController extends BaseController { ...@@ -76,7 +76,7 @@ public class ProjectController extends BaseController {
@PostMapping("/add") @PostMapping("/add")
public ResponseResult addProject(@RequestBody ProjectVO projectVO) { public ResponseResult addProject(@RequestBody ProjectVO projectVO) {
ProjectService.addProject(projectVO); ProjectService.addProject(projectVO);
behaviorService.pushBehavior(OPERATION, "添加项目配置:" + projectVO.getId(), request); behaviorService.pushBehaviorOld(OPERATION, "添加项目配置:" + projectVO.getId(), request);
return ResponseResult.success(); return ResponseResult.success();
} }
...@@ -93,7 +93,7 @@ public class ProjectController extends BaseController { ...@@ -93,7 +93,7 @@ public class ProjectController extends BaseController {
@PutMapping("/update") @PutMapping("/update")
public ResponseResult updateProject(@RequestBody ProjectVO projectVO) { public ResponseResult updateProject(@RequestBody ProjectVO projectVO) {
ProjectService.updateProject(projectVO); ProjectService.updateProject(projectVO);
behaviorService.pushBehavior(OPERATION, "修改项目:" + projectVO.getId(), request); behaviorService.pushBehaviorOld(OPERATION, "修改项目:" + projectVO.getId(), request);
return ResponseResult.success(); return ResponseResult.success();
} }
...@@ -102,7 +102,7 @@ public class ProjectController extends BaseController { ...@@ -102,7 +102,7 @@ public class ProjectController extends BaseController {
@DeleteMapping("/delete/{pid}") @DeleteMapping("/delete/{pid}")
public ResponseResult deleteProject(@PathVariable("pid") String pid) { public ResponseResult deleteProject(@PathVariable("pid") String pid) {
ProjectService.deleteProject(pid, UserThreadLocal.getProjectId()); ProjectService.deleteProject(pid, UserThreadLocal.getProjectId());
behaviorService.pushBehavior(OPERATION, "删除项目:" + pid, request); behaviorService.pushBehaviorOld(OPERATION, "删除项目:" + pid, request);
return ResponseResult.success(); return ResponseResult.success();
} }
...@@ -112,7 +112,7 @@ public class ProjectController extends BaseController { ...@@ -112,7 +112,7 @@ public class ProjectController extends BaseController {
public ResponseResult switchProjectShow(@PathVariable String pid) { public ResponseResult switchProjectShow(@PathVariable String pid) {
boolean result = ProjectService.switchProjectShow(pid); boolean result = ProjectService.switchProjectShow(pid);
if (result) { if (result) {
behaviorService.pushBehavior(OPERATION, "切换项目展示状态:" + pid, request); behaviorService.pushBehaviorOld(OPERATION, "切换项目展示状态:" + pid, request);
return ResponseResult.success(); return ResponseResult.success();
} else { } else {
return ResponseResult.failure("启动状态下的项目,不允许调整展示状态"); return ResponseResult.failure("启动状态下的项目,不允许调整展示状态");
...@@ -124,7 +124,7 @@ public class ProjectController extends BaseController { ...@@ -124,7 +124,7 @@ public class ProjectController extends BaseController {
@PutMapping("/switch/projectStart/{pid}") @PutMapping("/switch/projectStart/{pid}")
public ResponseResult switchProjectStart(@PathVariable String pid) { public ResponseResult switchProjectStart(@PathVariable String pid) {
ProjectService.switchProjectStart(pid); ProjectService.switchProjectStart(pid);
behaviorService.pushBehavior(OPERATION, "切换项目状态:" + pid, request); behaviorService.pushBehaviorOld(OPERATION, "切换项目状态:" + pid, request);
return ResponseResult.success(); return ResponseResult.success();
} }
...@@ -139,7 +139,7 @@ public class ProjectController extends BaseController { ...@@ -139,7 +139,7 @@ public class ProjectController extends BaseController {
@PostMapping(value = "/upload/img", headers = "content-type=multipart/form-data") @PostMapping(value = "/upload/img", headers = "content-type=multipart/form-data")
public ResponseResult uploadImg(@RequestParam("file") MultipartFile file) { public ResponseResult uploadImg(@RequestParam("file") MultipartFile file) {
ResponseResult responseResult = Tools.uploadFile(file, brandkbsImgPath, brandkbsImageUrl); ResponseResult responseResult = Tools.uploadFile(file, brandkbsImgPath, brandkbsImageUrl);
behaviorService.pushBehavior(OPERATION, "图片上传", request); behaviorService.pushBehaviorOld(OPERATION, "图片上传", request);
return responseResult; return responseResult;
} }
......
...@@ -78,7 +78,7 @@ public class UserController extends BaseController { ...@@ -78,7 +78,7 @@ public class UserController extends BaseController {
@PostMapping("/add") @PostMapping("/add")
public ResponseResult addUser(@RequestBody UserDTO userDTO) { public ResponseResult addUser(@RequestBody UserDTO userDTO) {
UserService.addUser(userDTO); UserService.addUser(userDTO);
behaviorService.pushBehavior(OPERATION, "添加用户:" + userDTO.getId(), request); behaviorService.pushBehaviorOld(OPERATION, "添加用户:" + userDTO.getId(), request);
return ResponseResult.success(); return ResponseResult.success();
} }
...@@ -90,7 +90,7 @@ public class UserController extends BaseController { ...@@ -90,7 +90,7 @@ public class UserController extends BaseController {
@Auth(role = RoleEnum.ADMIN) @Auth(role = RoleEnum.ADMIN)
public ResponseResult deleteUser(@RequestParam(value = "uid") String userId, @RequestParam(value = "pid") String pid) { public ResponseResult deleteUser(@RequestParam(value = "uid") String userId, @RequestParam(value = "pid") String pid) {
UserService.deleteUser(userId, pid); UserService.deleteUser(userId, pid);
behaviorService.pushBehavior(OPERATION, "删除用户:" + userId, request); behaviorService.pushBehaviorOld(OPERATION, "删除用户:" + userId, request);
return ResponseResult.success(); return ResponseResult.success();
} }
...@@ -98,7 +98,7 @@ public class UserController extends BaseController { ...@@ -98,7 +98,7 @@ public class UserController extends BaseController {
@PutMapping("/update") @PutMapping("/update")
public ResponseResult updateUser(@RequestBody UserDTO userDTO) { public ResponseResult updateUser(@RequestBody UserDTO userDTO) {
UserService.updateUser(userDTO); UserService.updateUser(userDTO);
behaviorService.pushBehavior(OPERATION, "编辑用户:" + userDTO, request); behaviorService.pushBehaviorOld(OPERATION, "编辑用户:" + userDTO, request);
return ResponseResult.success(); return ResponseResult.success();
} }
...@@ -121,7 +121,7 @@ public class UserController extends BaseController { ...@@ -121,7 +121,7 @@ public class UserController extends BaseController {
@Auth(role = RoleEnum.SUPER_ADMIN) @Auth(role = RoleEnum.SUPER_ADMIN)
public ResponseResult addSuperAdmin(@RequestBody UserDTO userDTO) { public ResponseResult addSuperAdmin(@RequestBody UserDTO userDTO) {
UserService.addSuperAdmin(userDTO); UserService.addSuperAdmin(userDTO);
behaviorService.pushBehavior(OPERATION, "添加超级管理员:" + userDTO.getId(), request); behaviorService.pushBehaviorOld(OPERATION, "添加超级管理员:" + userDTO.getId(), request);
return ResponseResult.success(); return ResponseResult.success();
} }
...@@ -132,7 +132,7 @@ public class UserController extends BaseController { ...@@ -132,7 +132,7 @@ public class UserController extends BaseController {
@Auth(role = RoleEnum.SUPER_ADMIN) @Auth(role = RoleEnum.SUPER_ADMIN)
public ResponseResult deleteSuperAdmin(@RequestParam(value = "uid") String userId) { public ResponseResult deleteSuperAdmin(@RequestParam(value = "uid") String userId) {
UserService.deleteSuperAdmin(userId); UserService.deleteSuperAdmin(userId);
behaviorService.pushBehavior(OPERATION, "删除超级管理员:" + userId, request); behaviorService.pushBehaviorOld(OPERATION, "删除超级管理员:" + userId, request);
return ResponseResult.success(); return ResponseResult.success();
} }
......
...@@ -129,10 +129,12 @@ public class AppSearchController extends BaseController { ...@@ -129,10 +129,12 @@ public class AppSearchController extends BaseController {
public ResponseResult searchWholeNetwork(@RequestBody SearchFilterDTO dto) { public ResponseResult searchWholeNetwork(@RequestBody SearchFilterDTO dto) {
long time = DateUtils.addDays(Tools.truncDate(new Date(), Constant.DAY_PATTERN), -89).getTime(); long time = DateUtils.addDays(Tools.truncDate(new Date(), Constant.DAY_PATTERN), -89).getTime();
if (time > dto.getStartTime()) { if (time > dto.getStartTime()) {
// 仅对查商业数据库时限制时间,查舆情库时本质上无时间限制
return ResponseResult.failure("仅能搜索近3个月内信息"); return ResponseResult.failure("仅能搜索近3个月内信息");
} }
Period periodDay = new Period(dto.getStartTime(), dto.getEndTime(), PeriodType.days()); Period periodDay = new Period(dto.getStartTime(), dto.getEndTime(), PeriodType.days());
if (periodDay.getDays() > 30) { if (periodDay.getDays() > 30) {
// 仅对查商业数据库时限制时间,查舆情库时本质上无时间限制
return ResponseResult.failure("时间跨度不能超过30天"); return ResponseResult.failure("时间跨度不能超过30天");
} }
return ResponseResult.success(markDataService.searchWholeNetwork(dto)); return ResponseResult.success(markDataService.searchWholeNetwork(dto));
......
...@@ -3,6 +3,9 @@ package com.zhiwei.brandkbs2.pojo; ...@@ -3,6 +3,9 @@ package com.zhiwei.brandkbs2.pojo;
import lombok.Getter; import lombok.Getter;
import lombok.Setter; import lombok.Setter;
import java.util.List;
import java.util.Map;
/** /**
* @ClassName: Behavior * @ClassName: Behavior
* @Description 用户行为实体类 * @Description 用户行为实体类
...@@ -12,7 +15,6 @@ import lombok.Setter; ...@@ -12,7 +15,6 @@ import lombok.Setter;
@Getter @Getter
@Setter @Setter
public class Behavior extends AbstractBaseMongo { public class Behavior extends AbstractBaseMongo {
/** /**
* 用户ID * 用户ID
*/ */
...@@ -43,6 +45,36 @@ public class Behavior extends AbstractBaseMongo { ...@@ -43,6 +45,36 @@ public class Behavior extends AbstractBaseMongo {
*/ */
private boolean backstage; private boolean backstage;
/**
* nickName
*/
private String nickName;
/**
* uri 访问路径
*/
private String uri;
/**
* 方法名
*/
private String methodName;
/**
* method HTTP 方法
*/
private String httpMethod;
/**
* 方法传入参数
*/
private List<Map<String, Object>> arguments;
/**
* 更新时间
*/
private Long updateTime;
/**
* 服务器地址
*/
private String severAddress;
@Getter @Getter
public static class Operation { public static class Operation {
...@@ -54,4 +86,20 @@ public class Behavior extends AbstractBaseMongo { ...@@ -54,4 +86,20 @@ public class Behavior extends AbstractBaseMongo {
this.backstage = backstage; this.backstage = backstage;
} }
} }
public static Behavior createBehaviorNew(String userId, String nickName, String projectId, String uri, String methodName, String httpMethod,
List<Map<String, Object>> requestArguments, Long CTime, Long updateTime, String severAddress, String clientAddress){
Behavior behavior = new Behavior();
behavior.setUserId(userId);
behavior.setNickName(nickName);
behavior.setProjectId(projectId);
behavior.setUri(uri);
behavior.setMethodName(methodName);
behavior.setHttpMethod(httpMethod);
behavior.setArguments(requestArguments);
behavior.setCTime(CTime);
behavior.setUpdateTime(updateTime);
behavior.setSeverAddress(severAddress);
behavior.setIp(clientAddress);
return behavior;
}
} }
...@@ -21,7 +21,7 @@ public interface BehaviorService { ...@@ -21,7 +21,7 @@ public interface BehaviorService {
* @param module 操作模块 * @param module 操作模块
* @param request 请求 * @param request 请求
*/ */
void pushBehavior(Behavior.Operation operation, String module, HttpServletRequest request); void pushBehaviorOld(Behavior.Operation operation, String module, HttpServletRequest request);
/** /**
* 分页查询用户行为列表 * 分页查询用户行为列表
......
...@@ -52,7 +52,7 @@ public class BehaviorServiceImpl implements BehaviorService { ...@@ -52,7 +52,7 @@ public class BehaviorServiceImpl implements BehaviorService {
private com.zhiwei.brandkbs2.util.MongoUtil mongoUtil; private com.zhiwei.brandkbs2.util.MongoUtil mongoUtil;
@Override @Override
public void pushBehavior(Behavior.Operation operation, String module, HttpServletRequest request) { public void pushBehaviorOld(Behavior.Operation operation, String module, HttpServletRequest request) {
try { try {
String userId = UserThreadLocal.getUserId(); String userId = UserThreadLocal.getUserId();
String projectId = UserThreadLocal.getProjectId(); String projectId = UserThreadLocal.getProjectId();
......
...@@ -928,4 +928,13 @@ public class Tools { ...@@ -928,4 +928,13 @@ public class Tools {
return null; return null;
} }
/**
* 判断header中是否为空值
*
* @param o
* @return
*/
public static boolean isNullOrUndefined(Object o) {
return (isEmpty(o) || Objects.equals("undefined", o));
}
} }
\ No newline at end of file
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment