DuplicateCheckController.java 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. package org.jeecg.modules.system.controller;
  2. import javax.servlet.http.HttpServletRequest;
  3. import org.apache.commons.lang.StringUtils;
  4. import org.jeecg.common.api.vo.Result;
  5. import org.jeecg.common.constant.SymbolConstant;
  6. import org.jeecg.common.util.SqlInjectionUtil;
  7. import org.jeecg.modules.system.mapper.SysDictMapper;
  8. import org.jeecg.modules.system.model.DuplicateCheckVo;
  9. import org.jeecg.modules.system.security.DictQueryBlackListHandler;
  10. import org.springframework.beans.factory.annotation.Autowired;
  11. import org.springframework.web.bind.annotation.ExceptionHandler;
  12. import org.springframework.web.bind.annotation.RequestMapping;
  13. import org.springframework.web.bind.annotation.RequestMethod;
  14. import org.springframework.web.bind.annotation.RestController;
  15. import io.swagger.annotations.Api;
  16. import io.swagger.annotations.ApiOperation;
  17. import lombok.extern.slf4j.Slf4j;
  18. /**
  19. * @Title: DuplicateCheckAction
  20. * @Description: 重复校验工具
  21. * @Author 张代浩
  22. * @Date 2019-03-25
  23. * @Version V1.0
  24. */
  25. @Slf4j
  26. @RestController
  27. @RequestMapping("/sys/duplicate")
  28. @Api(tags="重复校验")
  29. public class DuplicateCheckController {
  30. @Autowired
  31. SysDictMapper sysDictMapper;
  32. @Autowired
  33. DictQueryBlackListHandler dictQueryBlackListHandler;
  34. /**
  35. * 校验数据是否在系统中是否存在
  36. *
  37. * @return
  38. */
  39. @RequestMapping(value = "/check", method = RequestMethod.GET)
  40. @ApiOperation("重复校验接口")
  41. public Result<String> doDuplicateCheck(DuplicateCheckVo duplicateCheckVo, HttpServletRequest request) {
  42. Long num = null;
  43. log.debug("----duplicate check------:"+ duplicateCheckVo.toString());
  44. //关联表字典(举例:sys_user,realname,id)
  45. //SQL注入校验(只限制非法串改数据库)
  46. final String[] sqlInjCheck = {duplicateCheckVo.getTableName(),duplicateCheckVo.getFieldName()};
  47. SqlInjectionUtil.filterContent(sqlInjCheck);
  48. // update-begin-author:taoyan date:20211227 for: JTC-25 【online报表】oracle 操作问题 录入弹框啥都不填直接保存 ①编码不是应该提示必填么?②报错也应该是具体文字提示,不是后台错误日志
  49. if(StringUtils.isEmpty(duplicateCheckVo.getFieldVal())){
  50. Result rs = new Result();
  51. rs.setCode(500);
  52. rs.setSuccess(true);
  53. rs.setMessage("数据为空,不作处理!");
  54. return rs;
  55. }
  56. //update-begin-author:taoyan date:20220329 for: VUEN-223【安全漏洞】当前被攻击的接口
  57. String checkSql = duplicateCheckVo.getTableName() + SymbolConstant.COMMA + duplicateCheckVo.getFieldName() + SymbolConstant.COMMA;
  58. if(!dictQueryBlackListHandler.isPass(checkSql)){
  59. return Result.error(dictQueryBlackListHandler.getError());
  60. }
  61. //update-end-author:taoyan date:20220329 for: VUEN-223【安全漏洞】当前被攻击的接口
  62. // update-end-author:taoyan date:20211227 for: JTC-25 【online报表】oracle 操作问题 录入弹框啥都不填直接保存 ①编码不是应该提示必填么?②报错也应该是具体文字提示,不是后台错误日志
  63. if (StringUtils.isNotBlank(duplicateCheckVo.getDataId())) {
  64. // [2].编辑页面校验
  65. num = sysDictMapper.duplicateCheckCountSql(duplicateCheckVo);
  66. } else {
  67. // [1].添加页面校验
  68. num = sysDictMapper.duplicateCheckCountSqlNoDataId(duplicateCheckVo);
  69. }
  70. if (num == null || num == 0) {
  71. // 该值可用
  72. return Result.ok("该值可用!");
  73. } else {
  74. // 该值不可用
  75. log.info("该值不可用,系统中已存在!");
  76. return Result.error("该值不可用,系统中已存在!");
  77. }
  78. }
  79. /**
  80. * VUEN-2584【issue】平台sql注入漏洞几个问题
  81. * 部分特殊函数 可以将查询结果混夹在错误信息中,导致数据库的信息暴露
  82. * @param e
  83. * @return
  84. */
  85. @ExceptionHandler(java.sql.SQLException.class)
  86. public Result<?> handleSQLException(Exception e){
  87. String msg = e.getMessage();
  88. String extractvalue = "extractvalue";
  89. String updatexml = "updatexml";
  90. if(msg!=null && (msg.toLowerCase().indexOf(extractvalue)>=0 || msg.toLowerCase().indexOf(updatexml)>=0)){
  91. return Result.error("校验失败,sql解析异常!");
  92. }
  93. return Result.error("校验失败,sql解析异常!" + msg);
  94. }
  95. }