package org.jeecg.modules.system.service.impl; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import lombok.extern.slf4j.Slf4j; import org.jeecg.common.constant.CacheConstant; import org.jeecg.common.constant.CommonConstant; import org.jeecg.common.system.vo.DictModel; import org.jeecg.common.system.vo.DictModelMany; import org.jeecg.common.system.vo.DictQuery; import org.jeecg.common.util.SqlInjectionUtil; import org.jeecg.common.util.oConvertUtils; import org.jeecg.modules.system.entity.SysDict; import org.jeecg.modules.system.entity.SysDictItem; import org.jeecg.modules.system.mapper.SysDictItemMapper; import org.jeecg.modules.system.mapper.SysDictMapper; import org.jeecg.modules.system.model.TreeSelectModel; import org.jeecg.modules.system.service.ISysDictService; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.cache.annotation.Cacheable; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; import java.util.stream.Collectors; /** *

* 字典表 服务实现类 *

* * @Author zhangweijian * @since 2018-12-28 */ @Service @Slf4j public class SysDictServiceImpl extends ServiceImpl implements ISysDictService { @Autowired private SysDictMapper sysDictMapper; @Autowired private SysDictItemMapper sysDictItemMapper; /** * 通过查询指定code 获取字典 * @param code * @return */ @Override @Cacheable(value = CacheConstant.SYS_DICT_CACHE,key = "#code", unless = "#result == null ") public List queryDictItemsByCode(String code) { log.debug("无缓存dictCache的时候调用这里!"); return sysDictMapper.queryDictItemsByCode(code); } @Override @Cacheable(value = CacheConstant.SYS_ENABLE_DICT_CACHE,key = "#code", unless = "#result == null ") public List queryEnableDictItemsByCode(String code) { log.debug("无缓存dictCache的时候调用这里!"); return sysDictMapper.queryEnableDictItemsByCode(code); } @Override public Map> queryDictItemsByCodeList(List dictCodeList) { List list = sysDictMapper.queryDictItemsByCodeList(dictCodeList); Map> dictMap = new HashMap<>(); for (DictModelMany dict : list) { List dictItemList = dictMap.computeIfAbsent(dict.getDictCode(), i -> new ArrayList<>()); dict.setDictCode(null); dictItemList.add(new DictModel(dict.getValue(), dict.getText())); } return dictMap; } @Override public Map> queryAllDictItems() { Map> res = new HashMap>(); List ls = sysDictMapper.selectList(null); LambdaQueryWrapper queryWrapper = new LambdaQueryWrapper(); queryWrapper.eq(SysDictItem::getStatus, 1); queryWrapper.orderByAsc(SysDictItem::getSortOrder); List sysDictItemList = sysDictItemMapper.selectList(queryWrapper); for (SysDict d : ls) { List dictModelList = sysDictItemList.stream().filter(s -> d.getId().equals(s.getDictId())).map(item -> { DictModel dictModel = new DictModel(); dictModel.setText(item.getItemText()); dictModel.setValue(item.getItemValue()); return dictModel; }).collect(Collectors.toList()); res.put(d.getDictCode(), dictModelList); } log.debug("-------登录加载系统字典-----" + res.toString()); return res; } /** * 通过查询指定code 获取字典值text * @param code * @param key * @return */ @Override @Cacheable(value = CacheConstant.SYS_DICT_CACHE,key = "#code+':'+#key", unless = "#result == null ") public String queryDictTextByKey(String code, String key) { log.debug("无缓存dictText的时候调用这里!"); return sysDictMapper.queryDictTextByKey(code, key); } @Override public Map> queryManyDictByKeys(List dictCodeList, List keys) { List list = sysDictMapper.queryManyDictByKeys(dictCodeList, keys); Map> dictMap = new HashMap<>(); for (DictModelMany dict : list) { List dictItemList = dictMap.computeIfAbsent(dict.getDictCode(), i -> new ArrayList<>()); dictItemList.add(new DictModel(dict.getValue(), dict.getText())); } return dictMap; } /** * 通过查询指定table的 text code 获取字典 * dictTableCache采用redis缓存有效期10分钟 * @param table * @param text * @param code * @return */ @Override //@Cacheable(value = CacheConstant.SYS_DICT_TABLE_CACHE) public List queryTableDictItemsByCode(String table, String text, String code) { log.debug("无缓存dictTableList的时候调用这里!"); return sysDictMapper.queryTableDictItemsByCode(table,text,code); } @Override public List queryTableDictItemsByCodeAndFilter(String table, String text, String code, String filterSql) { log.debug("无缓存dictTableList的时候调用这里!"); return sysDictMapper.queryTableDictItemsByCodeAndFilter(table,text,code,filterSql); } /** * 通过查询指定table的 text code 获取字典值text * dictTableCache采用redis缓存有效期10分钟 * @param table * @param text * @param code * @param key * @return */ @Override @Cacheable(value = CacheConstant.SYS_DICT_TABLE_CACHE, unless = "#result == null ") public String queryTableDictTextByKey(String table,String text,String code, String key) { log.debug("无缓存dictTable的时候调用这里!"); return sysDictMapper.queryTableDictTextByKey(table,text,code,key); } @Override public List queryTableDictTextByKeys(String table, String text, String code, List keys) { return sysDictMapper.queryTableDictTextByKeys(table, text, code, keys); } @Override public List queryTableDictByKeys(String table, String text, String code, String keys) { return this.queryTableDictByKeys(table, text, code, keys, true); } /** * 通过查询指定table的 text code 获取字典,包含text和value * dictTableCache采用redis缓存有效期10分钟 * @param table * @param text * @param code * @param keys (逗号分隔) * @param delNotExist 是否移除不存在的项,默认为true,设为false如果某个key不存在数据库中,则直接返回key本身 * @return */ @Override //update-begin--Author:lvdandan Date:20201204 for:JT-36【online】树形列表bug修改后,还是显示原来值 暂时去掉缓存 //@Cacheable(value = CacheConstant.SYS_DICT_TABLE_BY_KEYS_CACHE) //update-end--Author:lvdandan Date:20201204 for:JT-36【online】树形列表bug修改后,还是显示原来值 暂时去掉缓存 public List queryTableDictByKeys(String table, String text, String code, String keys, boolean delNotExist) { if(oConvertUtils.isEmpty(keys)){ return null; } String[] keyArray = keys.split(","); List dicts = sysDictMapper.queryTableDictByKeys(table, text, code, keyArray); List texts = new ArrayList<>(dicts.size()); // update-begin--author:sunjianlei--date:20210514--for:新增delNotExist参数,设为false不删除数据库里不存在的key ---- // 查询出来的顺序可能是乱的,需要排个序 for (String key : keyArray) { List res = dicts.stream().filter(i -> key.equals(i.getValue())).collect(Collectors.toList()); if (res.size() > 0) { texts.add(res.get(0).getText()); } else if (!delNotExist) { texts.add(key); } } // update-end--author:sunjianlei--date:20210514--for:新增delNotExist参数,设为false不删除数据库里不存在的key ---- return texts; } /** * 根据字典类型id删除关联表中其对应的数据 */ @Override public boolean deleteByDictId(SysDict sysDict) { sysDict.setDelFlag(CommonConstant.DEL_FLAG_1); return this.updateById(sysDict); } @Override @Transactional public Integer saveMain(SysDict sysDict, List sysDictItemList) { int insert=0; try{ insert = sysDictMapper.insert(sysDict); if (sysDictItemList != null) { for (SysDictItem entity : sysDictItemList) { entity.setDictId(sysDict.getId()); entity.setStatus(1); sysDictItemMapper.insert(entity); } } }catch(Exception e){ return insert; } return insert; } @Override public List queryAllDepartBackDictModel() { return baseMapper.queryAllDepartBackDictModel(); } @Override public List queryAllUserBackDictModel() { return baseMapper.queryAllUserBackDictModel(); } @Override public List queryTableDictItems(String table, String text, String code, String keyword) { return baseMapper.queryTableDictItems(table, text, code, "%"+keyword+"%"); } @Override public List queryLittleTableDictItems(String table, String text, String code, String condition, String keyword, int pageSize) { Page page = new Page(1, pageSize); page.setSearchCount(false); String filterSql = getFilterSql(text, code, condition, keyword); IPage pageList = baseMapper.queryTableDictWithFilter(page, table, text, code, filterSql); return pageList.getRecords(); } /** * 获取条件语句 * @param text * @param code * @param condition * @param keyword * @return */ private String getFilterSql(String text, String code, String condition, String keyword){ String keywordSql = null, filterSql = "", sql_where = " where "; if(oConvertUtils.isNotEmpty(keyword)){ // 判断是否是多选 if (keyword.contains(",")) { String inKeywords = "\"" + keyword.replaceAll(",", "\",\"") + "\""; keywordSql = "(" + text + " in (" + inKeywords + ") or " + code + " in (" + inKeywords + "))"; } else { keywordSql = "("+text + " like '%"+keyword+"%' or "+ code + " like '%"+keyword+"%')"; } } if(oConvertUtils.isNotEmpty(condition) && oConvertUtils.isNotEmpty(keywordSql)){ filterSql+= sql_where + condition + " and " + keywordSql; }else if(oConvertUtils.isNotEmpty(condition)){ filterSql+= sql_where + condition; }else if(oConvertUtils.isNotEmpty(keywordSql)){ filterSql+= sql_where + keywordSql; } return filterSql; } @Override public List queryAllTableDictItems(String table, String text, String code, String condition, String keyword) { String filterSql = getFilterSql(text, code, condition, keyword); List ls = baseMapper.queryAllTableDictItems(table, text, code, filterSql); return ls; } @Override public List queryTreeList(Map query,String table, String text, String code, String pidField,String pid,String hasChildField) { return baseMapper.queryTreeList(query,table, text, code, pidField, pid,hasChildField); } @Override public void deleteOneDictPhysically(String id) { this.baseMapper.deleteOneById(id); this.sysDictItemMapper.delete(new LambdaQueryWrapper().eq(SysDictItem::getDictId,id)); } @Override public void updateDictDelFlag(int delFlag, String id) { baseMapper.updateDictDelFlag(delFlag,id); } @Override public List queryDeleteList() { return baseMapper.queryDeleteList(); } @Override public List queryDictTablePageList(DictQuery query, int pageSize, int pageNo) { Page page = new Page(pageNo,pageSize,false); Page pageList = baseMapper.queryDictTablePageList(page, query); return pageList.getRecords(); } @Override public List getDictItems(String dictCode) { List ls; if (dictCode.contains(",")) { //关联表字典(举例:sys_user,realname,id) String[] params = dictCode.split(","); if (params.length < 3) { // 字典Code格式不正确 return null; } //SQL注入校验(只限制非法串改数据库) final String[] sqlInjCheck = {params[0], params[1], params[2]}; SqlInjectionUtil.filterContent(sqlInjCheck); if (params.length == 4) { // SQL注入校验(查询条件SQL 特殊check,此方法仅供此处使用) SqlInjectionUtil.specialFilterContent(params[3]); ls = this.queryTableDictItemsByCodeAndFilter(params[0], params[1], params[2], params[3]); } else if (params.length == 3) { ls = this.queryTableDictItemsByCode(params[0], params[1], params[2]); } else { // 字典Code格式不正确 return null; } } else { //字典表 ls = this.queryDictItemsByCode(dictCode); } return ls; } @Override public List loadDict(String dictCode, String keyword, Integer pageSize) { if (dictCode.contains(",")) { //update-begin-author:taoyan date:20210329 for: 下拉搜索不支持表名后加查询条件 String[] params = dictCode.split(","); String condition = null; if (params.length != 3 && params.length != 4) { // 字典Code格式不正确 return null; } else if (params.length == 4) { condition = params[3]; } List ls; if (pageSize != null) { ls = this.queryLittleTableDictItems(params[0], params[1], params[2], condition, keyword, pageSize); } else { ls = this.queryAllTableDictItems(params[0], params[1], params[2], condition, keyword); } //update-end-author:taoyan date:20210329 for: 下拉搜索不支持表名后加查询条件 return ls; } else { // 字典Code格式不正确 return null; } } }