ffeae2ab31966d979e159556218bad685b739a05.svn-base 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  1. package org.jeecg.modules.system.controller;
  2. import java.util.Arrays;
  3. import javax.servlet.http.HttpServletRequest;
  4. import org.jeecg.common.api.vo.Result;
  5. import org.jeecg.common.system.query.QueryGenerator;
  6. import org.jeecg.common.util.oConvertUtils;
  7. import org.jeecg.modules.system.entity.SysLog;
  8. import org.jeecg.modules.system.entity.SysRole;
  9. import org.jeecg.modules.system.service.ISysLogService;
  10. import org.springframework.beans.factory.annotation.Autowired;
  11. import org.springframework.web.bind.annotation.RequestMapping;
  12. import org.springframework.web.bind.annotation.RequestMethod;
  13. import org.springframework.web.bind.annotation.RequestParam;
  14. import org.springframework.web.bind.annotation.RestController;
  15. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  16. import com.baomidou.mybatisplus.core.metadata.IPage;
  17. import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
  18. import lombok.extern.slf4j.Slf4j;
  19. /**
  20. * <p>
  21. * 系统日志表 前端控制器
  22. * </p>
  23. *
  24. * @Author zhangweijian
  25. * @since 2018-12-26
  26. */
  27. @RestController
  28. @RequestMapping("/sys/log")
  29. @Slf4j
  30. public class SysLogController {
  31. @Autowired
  32. private ISysLogService sysLogService;
  33. /**
  34. * @功能:查询日志记录
  35. * @param syslog
  36. * @param pageNo
  37. * @param pageSize
  38. * @param req
  39. * @return
  40. */
  41. @RequestMapping(value = "/list", method = RequestMethod.GET)
  42. public Result<IPage<SysLog>> queryPageList(SysLog syslog,@RequestParam(name="pageNo", defaultValue="1") Integer pageNo,
  43. @RequestParam(name="pageSize", defaultValue="10") Integer pageSize,HttpServletRequest req) {
  44. Result<IPage<SysLog>> result = new Result<IPage<SysLog>>();
  45. QueryWrapper<SysLog> queryWrapper = QueryGenerator.initQueryWrapper(syslog, req.getParameterMap());
  46. Page<SysLog> page = new Page<SysLog>(pageNo, pageSize);
  47. //日志关键词
  48. String keyWord = req.getParameter("keyWord");
  49. if(oConvertUtils.isNotEmpty(keyWord)) {
  50. queryWrapper.like("log_content",keyWord);
  51. }
  52. //TODO 过滤逻辑处理
  53. //TODO begin、end逻辑处理
  54. //TODO 一个强大的功能,前端传一个字段字符串,后台只返回这些字符串对应的字段
  55. //创建时间/创建人的赋值
  56. IPage<SysLog> pageList = sysLogService.page(page, queryWrapper);
  57. log.info("查询当前页:"+pageList.getCurrent());
  58. log.info("查询当前页数量:"+pageList.getSize());
  59. log.info("查询结果数量:"+pageList.getRecords().size());
  60. log.info("数据总数:"+pageList.getTotal());
  61. result.setSuccess(true);
  62. result.setResult(pageList);
  63. return result;
  64. }
  65. /**
  66. * @功能:删除单个日志记录
  67. * @param id
  68. * @return
  69. */
  70. @RequestMapping(value = "/delete", method = RequestMethod.POST)
  71. public Result<SysLog> delete(@RequestParam(name="id",required=true) String id) {
  72. Result<SysLog> result = new Result<SysLog>();
  73. SysLog sysLog = sysLogService.getById(id);
  74. if(sysLog==null) {
  75. result.error500("未找到对应实体");
  76. }else {
  77. boolean ok = sysLogService.removeById(id);
  78. if(ok) {
  79. result.success("删除成功!");
  80. }
  81. }
  82. return result;
  83. }
  84. /**
  85. * @功能:批量,全部清空日志记录
  86. * @param ids
  87. * @return
  88. */
  89. @RequestMapping(value = "/deleteBatch", method = RequestMethod.POST)
  90. public Result<SysRole> deleteBatch(@RequestParam(name="ids",required=true) String ids) {
  91. Result<SysRole> result = new Result<SysRole>();
  92. if(ids==null || "".equals(ids.trim())) {
  93. result.error500("参数不识别!");
  94. }else {
  95. if("allclear".equals(ids)) {
  96. this.sysLogService.removeAll();
  97. result.success("清除成功!");
  98. }
  99. this.sysLogService.removeByIds(Arrays.asList(ids.split(",")));
  100. result.success("删除成功!");
  101. }
  102. return result;
  103. }
  104. }