From 40bfb646d1b962d33841c1ebbceb0dd7cb668bfb Mon Sep 17 00:00:00 2001 From: liujie <1793218484@qq.com> Date: 星期二, 29 四月 2025 14:54:04 +0800 Subject: [PATCH] 后台日志管理 --- springcloud_k8s_panzhihuazhihuishequ/service_sangeshenbian/src/main/java/com/panzhihua/sangeshenbian/service/impl/ComplaintServiceImpl.java | 242 ++++++++++++++++++++++++++++++++--------------- 1 files changed, 163 insertions(+), 79 deletions(-) diff --git a/springcloud_k8s_panzhihuazhihuishequ/service_sangeshenbian/src/main/java/com/panzhihua/sangeshenbian/service/impl/ComplaintServiceImpl.java b/springcloud_k8s_panzhihuazhihuishequ/service_sangeshenbian/src/main/java/com/panzhihua/sangeshenbian/service/impl/ComplaintServiceImpl.java index 2e4d59c..3fd561c 100644 --- a/springcloud_k8s_panzhihuazhihuishequ/service_sangeshenbian/src/main/java/com/panzhihua/sangeshenbian/service/impl/ComplaintServiceImpl.java +++ b/springcloud_k8s_panzhihuazhihuishequ/service_sangeshenbian/src/main/java/com/panzhihua/sangeshenbian/service/impl/ComplaintServiceImpl.java @@ -2,7 +2,6 @@ import cn.hutool.core.bean.BeanUtil; import cn.hutool.core.collection.CollUtil; -import cn.hutool.core.collection.CollectionUtil; import cn.idev.excel.EasyExcel; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper; @@ -12,8 +11,12 @@ import com.panzhihua.common.exceptions.ServiceException; import com.panzhihua.common.model.vos.LoginUserInfoVO; import com.panzhihua.common.model.vos.sangeshenbian.SystemUserVo; +import com.panzhihua.common.redis.RedisUtils; +import com.panzhihua.common.utlis.StringUtils; +import com.panzhihua.sangeshenbian.config.AutoColumnWidthStrategy; import com.panzhihua.sangeshenbian.dao.ComplaintMapper; import com.panzhihua.sangeshenbian.enums.AuditStatusEnum; +import com.panzhihua.sangeshenbian.enums.ComplaintExportEnum; import com.panzhihua.sangeshenbian.enums.ProcessStatusEnum; import com.panzhihua.sangeshenbian.enums.RateEnum; import com.panzhihua.sangeshenbian.enums.ReportTypeEnum; @@ -26,14 +29,14 @@ import com.panzhihua.sangeshenbian.model.vo.ComplaintVO; import com.panzhihua.sangeshenbian.model.vo.DispatchVO; import com.panzhihua.sangeshenbian.service.*; -import com.panzhihua.sangeshenbian.utils.FileUtil; import com.panzhihua.sangeshenbian.warpper.IdentityInformation; import com.panzhihua.sangeshenbian.warpper.MgtComplaintQuery; import com.panzhihua.sangeshenbian.warpper.PermissionsVO; +import jodd.util.StringUtil; import lombok.RequiredArgsConstructor; import lombok.extern.slf4j.Slf4j; +import org.springframework.beans.BeanUtils; import org.springframework.context.annotation.Lazy; -import org.springframework.core.io.ClassPathResource; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; @@ -71,6 +74,7 @@ private final HttpServletResponse response; private final IPartyMemberService partyMemberService; private final IdentityInformationService identityInformationService; + private final RedisUtils redisUtils; @Override public void saveComplaint(Complaint complaint, LoginUserInfoVO loginUserInfoVO) { @@ -176,7 +180,34 @@ } @Override + @Transactional(rollbackFor = Exception.class) + public void saveAndReport(ComplaintVO complaintVO, LoginUserInfoVO loginUserInfo) { + Complaint complaint = new Complaint(); + BeanUtil.copyProperties(complaintVO, complaint); + saveComplaint(complaint, loginUserInfo); + ComplaintReportDTO dto = new ComplaintReportDTO(); + dto.setComplaintId(complaint.getId()); + dto.setComment(complaintVO.getComment()); + saveReport(dto, loginUserInfo); + } + + @Override + @Transactional(rollbackFor = Exception.class) + public void saveAndComplete(ComplaintSaveAndCompleteDTO complaintVO, LoginUserInfoVO loginUserInfo) { + Complaint complaint = new Complaint(); + BeanUtil.copyProperties(complaintVO, complaint); + saveComplaint(complaint, loginUserInfo); + + ComplaintCompletionDTO complaintCompletionDTO = complaintVO.getComplaintCompletionDTO(); + complaintCompletionDTO.setComplaintId(complaint.getId()); + complaintCompletionDTO.setId(complaint.getId()); + saveResult(complaintCompletionDTO, loginUserInfo); + } + + @Override public Page<ComplaintVO> complaintList(ComplaintQuery query, LoginUserInfoVO loginUserInfoVO) { + + Page<ComplaintVO> page = new Page<>(query.getPageNum(), query.getPageSize()); //判断当前登录用户级别,查询对应工单 Optional<SystemUser> systemUserByPhone = systemUserService.getSystemUserAdminByPhone(loginUserInfoVO.getPhone()); @@ -185,6 +216,7 @@ //获取当前身份,1=党员,2=管理员 IdentityInformation identityInformation = identityInformationService.getCurrentIdentityInformation(loginUserInfoVO); Integer identity = identityInformation.getIdentity(); + query.setUserId(loginUserInfoVO.getUserId()); //上级 if (systemUserByPhone.isPresent() && null != identity && identity == 2) { SystemUser systemUser = systemUserByPhone.get(); @@ -220,7 +252,17 @@ //查询对应诉求 //page = baseMapper.selectComplaintPage(page, query, targetId, isSuperior); page = baseMapper.selectComplaintPage1(page, query, accountLevel, targetId); - page.getRecords().forEach(s -> buttonPermission(s, systemUserByPhone, loginUserInfoVO)); + + for (ComplaintVO s : page.getRecords()) { + buttonPermission(s, systemUserByPhone, loginUserInfoVO); + Integer auditButtonStatus = s.getAuditButtonStatus(); + + Long reporterId = s.getReporterId(); + Long superiorId = s.getSuperiorId2(); + if (!targetId.equals(reporterId) && !targetId.equals(superiorId) && (s.getStatus() == 5)) { + s.setStatus(0); + } + } return page; } @@ -232,7 +274,9 @@ vo.setListControlsButtonStatus(1); vo.setEvaluateButtonStatus(1); vo.setAuditButtonStatus(1); - + // 获取身份 + IdentityInformation currentIdentityInformation = identityInformationService.getCurrentIdentityInformation(loginUserInfo); + Integer identity = currentIdentityInformation.getIdentity(); ComplaintAuditRecord one = complaintAuditRecordService.getOne(new LambdaQueryWrapper<ComplaintAuditRecord>() .eq(ComplaintAuditRecord::getComplaintId, vo.getId()) // .ne(ComplaintAuditRecord::getAuditType, 1) @@ -244,8 +288,12 @@ SystemUser systemUser = systemUserByPhone.get(); Integer accountLevel = systemUser.getAccountLevel(); Integer isAdmin = systemUser.getIsAdmin(); - //非党员用户,必须是管理员有权限 - if (accountLevel.compareTo(vo.getReportType()) == 0 && ((accountLevel != 5 && 1 == isAdmin) || accountLevel == 5)) { + //当前身份是管理员 + if (2 == identity && accountLevel.compareTo(vo.getReportType()) == 0 && (accountLevel != 5 && 1 == isAdmin)) { + vo.setListControlsButtonStatus(0); + } + //如果当前身份是党员 + if (1 == identity && 5 == vo.getReportType()) { vo.setListControlsButtonStatus(0); } } else { @@ -256,19 +304,16 @@ } //有审核数据,且正在办理 if (null != one && (vo.getStatus() == 0 || vo.getStatus() == 1 || vo.getStatus() == 2 || vo.getStatus() == 6)) { - - //区分是上报数据还是下派数据 if (one.getAuditType() == 2 || one.getAuditType() == 1) { //判断当前审核状态 if (one.getAuditStatus() == 1) { //审核状态为通过,则权限给到上报审核的这一层 - if (systemUserByPhone.isPresent()) { + if (systemUserByPhone.isPresent() && identity == 2) { SystemUser systemUser = systemUserByPhone.get(); Integer accountLevel = systemUser.getAccountLevel(); - Integer isAdmin = systemUser.getIsAdmin(); //非党员用户,必须是管理员有权限 - if (accountLevel.compareTo(one.getReportType()) == 0 && accountLevel != 5 && 1 == isAdmin) { + if (accountLevel.compareTo(one.getReportType()) == 0) { vo.setListControlsButtonStatus(0); } } @@ -296,8 +341,12 @@ SystemUser systemUser = systemUserByPhone.get(); Integer accountLevel = systemUser.getAccountLevel(); Integer isAdmin = systemUser.getIsAdmin(); - //非党员用户,必须是管理员有权限 - if (accountLevel.compareTo(vo.getReportType()) == 0 && ((accountLevel != 5 && 1 == isAdmin) || accountLevel == 5)) { + //当前身份是管理员 + if (2 == identity && accountLevel.compareTo(vo.getReportType()) == 0 && (accountLevel != 5 && 1 == isAdmin)) { + vo.setListControlsButtonStatus(0); + } + //如果当前身份是党员 + if (1 == identity && 5 == vo.getReportType()) { vo.setListControlsButtonStatus(0); } } else { @@ -319,46 +368,8 @@ Integer accountLevel = systemUser.getAccountLevel(); Integer isAdmin = systemUser.getIsAdmin(); //非党员用户,必须是管理员有权限 - if (accountLevel.compareTo(one.getReportType()) == 0 && ((accountLevel != 5 && 1 == isAdmin) || accountLevel == 5)) { + if (accountLevel.compareTo(one.getReportType()) == 0 && 1 == isAdmin && 2 == identity) { vo.setListControlsButtonStatus(0); - } - } else { - if (vo.getReportType() == 5 && one.getReportType() == 5) { - vo.setListControlsButtonStatus(0); - } - } - } else { - //没有审核通过,则需要查询上一条审核通过的数据,如果没有则给到添加诉求的人 - ComplaintAuditRecord one1 = complaintAuditRecordService.getOne(new LambdaQueryWrapper<ComplaintAuditRecord>().eq(ComplaintAuditRecord::getComplaintId, vo.getId()) - .eq(ComplaintAuditRecord::getAuditType, 3).eq(ComplaintAuditRecord::getAuditStatus, 1).orderByDesc(ComplaintAuditRecord::getSort).last(" limit 0, 1")); - if (null != one1) { - if (systemUserByPhone.isPresent()) { - SystemUser systemUser = systemUserByPhone.get(); - Integer accountLevel = systemUser.getAccountLevel(); - Integer isAdmin = systemUser.getIsAdmin(); - //非党员用户,必须是管理员有权限 - if (accountLevel.compareTo(one1.getReportType()) == 0 && ((accountLevel != 5 && 1 == isAdmin) || accountLevel == 5)) { - vo.setListControlsButtonStatus(0); - } - } else { - if (vo.getReportType() == 5 && one1.getReportType() == 5) { - vo.setListControlsButtonStatus(0); - } - } - } else { - //没有上一层审核通过的数据,则权限给到添加人 - if (systemUserByPhone.isPresent()) { - SystemUser systemUser = systemUserByPhone.get(); - Integer accountLevel = systemUser.getAccountLevel(); - Integer isAdmin = systemUser.getIsAdmin(); - //非党员用户,必须是管理员有权限 - if (accountLevel.compareTo(vo.getReportType()) == 0 && ((accountLevel != 5 && 1 == isAdmin) || accountLevel == 5)) { - vo.setListControlsButtonStatus(0); - } - } else { - if (vo.getReportType() == 5) { - vo.setListControlsButtonStatus(0); - } } } } @@ -372,8 +383,7 @@ String targetId = ""; Integer accountLevel = 5; //获取当前身份,1=党员,2=管理员 - IdentityInformation identityInformation = identityInformationService.getCurrentIdentityInformation(loginUserInfo); - if (2 == identityInformation.getIdentity()) { + if (2 == currentIdentityInformation.getIdentity()) { accountLevel = systemUser.getAccountLevel(); switch (accountLevel) { case 1: @@ -417,7 +427,12 @@ SystemUser systemUser = systemUserByPhone.get(); Integer accountLevel = systemUser.getAccountLevel(); Integer isAdmin = systemUser.getIsAdmin(); - if (accountLevel.compareTo(vo.getReportType()) == 0 && ((accountLevel != 5 && 1 == isAdmin) || accountLevel == 5)) { + //当前不是党员身份,需要是管理员才有权限 + if (2 == identity && accountLevel.compareTo(vo.getReportType()) == 0 && accountLevel != 5 && 1 == isAdmin) { + vo.setEvaluateButtonStatus(0); + } + //当前是党员身份,只有是以党员身份提交的数据才有权限 + if (1 == identity && vo.getReportType() == 5) { vo.setEvaluateButtonStatus(0); } } else { @@ -426,6 +441,16 @@ } } } + + Long auditCreateBy = vo.getAuditCreateBy(); + Long userId = loginUserInfo.getUserId(); + if (null != auditCreateBy && auditCreateBy.compareTo(userId) == 0 && vo.getStatus() == 5) { + vo.setWithdrawButtonStatus(0); + } else { + vo.setWithdrawButtonStatus(1); + } + + } @@ -477,26 +502,28 @@ } ComplaintVO detail = baseMapper.getDetail(id); if (detail.getStatus().equals(0)) { - List<ComplaintFlow> list = complaintFlowService.lambdaQuery().eq(ComplaintFlow::getComplaintId, id).orderByAsc(ComplaintFlow::getCreateTime).list(); + List<ComplaintFlow> list = complaintFlowService.lambdaQuery().eq(ComplaintFlow::getComplaintId, id).orderByAsc(ComplaintFlow::getSort).list(); detail.setComplaintFlows(list); } //查询办理进度 List<ComplaintProgress> list = complaintProgressService.lambdaQuery().eq(ComplaintProgress::getComplaintId, id) .orderByAsc(ComplaintProgress::getCreateTime).list(); detail.setComplaintProgresses(list); -// detail.setAuditButtonStatus(1); -// detail.setEvaluateButtonStatus(1); -// if((detail.getStatus() == 5 || detail.getStatus() == 7) && systemUserByPhone.isPresent()){ -// ComplaintAuditRecord one = complaintAuditRecordService.getOne(new LambdaQueryWrapper<ComplaintAuditRecord>().eq(ComplaintAuditRecord::getComplaintId, detail.getId()) -// .eq(ComplaintAuditRecord::getLatestFlag, 1)); -// Integer isAdmin = systemUserByPhone.get().getIsAdmin(); -// if(one.getReportType().equals(accountLevel) && one.getSuperiorId().toString().equals(targetId) && 1 == isAdmin){ -// detail.setAuditButtonStatus(0); -// } -// } buttonPermission(detail, systemUserByPhone, loginUserInfoVO); + Long reporterId = detail.getReporterId(); + Long superiorId = detail.getSuperiorId2(); + if (!String.valueOf(reporterId).equals(targetId) && !String.valueOf(superiorId).equals(targetId) && detail.getStatus() == 5) { + detail.setStatus(0); + } + + +// if (auditButtonStatus == 1 && detail.getStatus() == 5 && !Objects.equals(detail.getAuditCreateBy(), loginUserInfoVO.getUserId())){ +// detail.setStatus(0); +// } + + // //已办结,显示评价按钮 @@ -537,8 +564,8 @@ if (identityInformationVO.getIdentity() == 2) { //1=党员,2=管理员 SystemUser systemUser = identityInformationVO.getSystemUser(); - name = systemUser.getName(); - }else if (identityInformationVO.getIdentity() == 1){ + name = systemUser.getName(); + } else if (identityInformationVO.getIdentity() == 1) { PartyMember partyMember = identityInformationVO.getPartyMember(); name = partyMember.getName(); } @@ -571,8 +598,8 @@ //1=党员,2=管理员 SystemUser systemUser = identityInformationVO.getSystemUser(); accountLevel = systemUser.getAccountLevel(); - name = systemUser.getName(); - }else if (identityInformationVO.getIdentity() == 1){ + name = systemUser.getName(); + } else if (identityInformationVO.getIdentity() == 1) { accountLevel = 5; PartyMember partyMember = identityInformationVO.getPartyMember(); name = partyMember.getName(); @@ -599,6 +626,7 @@ return complaintProgressService.lambdaQuery().eq(ComplaintProgress::getComplaintId, complaintId) .orderByAsc(ComplaintProgress::getCreateTime).list(); } + @Override @Transactional(rollbackFor = Exception.class) @@ -705,6 +733,41 @@ complaintAuditRecord.setReporterLevel(reporterLevel); complaintAuditRecord.setReporterId(reporterId); complaintAuditRecordService.save(complaintAuditRecord); + } + + @Override + public void reportWithdraw(ComplaintReportWithdrawDTO dto, LoginUserInfoVO loginUserInfoVO) { + ComplaintAuditRecord complaintAuditRecord = complaintAuditRecordService.getOne(new LambdaQueryWrapper<ComplaintAuditRecord>() + .eq(ComplaintAuditRecord::getComplaintId, dto.getComplaintId()) + .eq(ComplaintAuditRecord::getAuditType, 2) + .eq(ComplaintAuditRecord::getLatestFlag, true)); + if (Objects.isNull(complaintAuditRecord)) { + throw new ServiceException("未找到相关记录"); + } + complaintAuditRecord.setAuditStatus(3); + complaintAuditRecord.setUpdateBy(loginUserInfoVO.getUserId()); + complaintAuditRecord.setUpdateTime(new Date()); + complaintAuditRecord.setLatestFlag(false); + complaintAuditRecordService.updateById(complaintAuditRecord); + + // 获取上一条记录 + ComplaintAuditRecord lastRecord = complaintAuditRecordService.getOne(new LambdaQueryWrapper<ComplaintAuditRecord>() + .ne(ComplaintAuditRecord::getId, complaintAuditRecord.getId()) + .eq(ComplaintAuditRecord::getComplaintId, dto.getComplaintId()) + .eq(ComplaintAuditRecord::getAuditType, 2) + .eq(ComplaintAuditRecord::getLatestFlag, false) + .orderByDesc(ComplaintAuditRecord::getSort) + ); + if (Objects.nonNull(lastRecord)) { + // 复制上一条记录 + ComplaintAuditRecord newRecord = new ComplaintAuditRecord(); + BeanUtils.copyProperties(lastRecord, newRecord); + newRecord.setId(null); + newRecord.setLatestFlag(true); + newRecord.setUpdateBy(loginUserInfoVO.getUserId()); + newRecord.setUpdateTime(new Date()); + complaintAuditRecordService.save(newRecord); + } } @Override @@ -842,6 +905,7 @@ Long superiorId; int reportType; String departmentName = ""; + String reporter = ""; if (identityInformation.getIdentity() == 1) { PartyMember partyMember = partyMemberService.getPartyMemberByPhone(loginUserInfoVO.getPhone()); superiorId = partyMember.getCommunityId(); @@ -850,12 +914,14 @@ } reportType = ReportTypeEnum.COMMUNITY.getCode(); departmentName = partyMember.getDistricts() + "-" + partyMember.getStreet() + "-" + partyMember.getCommunity(); + reporter = partyMember.getName(); } else if (identityInformation.getIdentity() == 2 && systemUser != null) { int accountLevel = systemUser.getAccountLevel(); // 改为基本类型 if (accountLevel == 1) { throw new ServiceException("市级账号,无法延期申请!"); } reportType = accountLevel - 1; + reporter = systemUser.getName(); // 使用基本类型比较并补充默认分支 if (accountLevel == ReportTypeEnum.COMMUNITY.getCode()) { @@ -912,7 +978,7 @@ record1.setCreateTime(new Date(System.currentTimeMillis())); record1.setUpdateBy(loginUserInfoVO.getUserId()); record1.setUpdateTime(new Date(System.currentTimeMillis())); - record1.setReporter(loginUserInfoVO.getNickName()); + record1.setReporter(reporter); record1.setReportType(reportType); record1.setSuperiorId(superiorId); record1.setSort(count + 1); @@ -960,6 +1026,8 @@ if (Objects.isNull(complaintAuditRecord)) { throw new ServiceException("诉求延期申请不存在"); } + complaintAuditRecord.setAuditorName(systemUser.getName()); + complaintAuditRecord.setAuditorPhone(systemUser.getPhone()); //审核通过后,设置诉求延期 if (complaintAuditRecord.getAuditType().equals(1) && complaintAuditRecord.getAuditStatus().equals(0) && dto.getAuditResult().equals(1)) { Complaint complaint = getById(complaintAuditRecord.getComplaintId()); @@ -998,7 +1066,7 @@ List<DispatchVO> dispatchVOList = new ArrayList<>(); if (accountLevel == ReportTypeEnum.STREET.getCode()) { String streetId = adminUser.getStreetId(); - List<ComAct> list = comActService.list(new LambdaQueryWrapper<ComAct>().eq(ComAct::getStreetId, streetId).eq(ComAct::getState, 0)); + List<ComAct> list = comActService.list(new LambdaQueryWrapper<ComAct>().eq(ComAct::getStreetId, streetId)); for (ComAct comAct : list) { DispatchVO dispatchVO = new DispatchVO(); dispatchVO.setId(comAct.getCommunityId().toString()); @@ -1109,12 +1177,21 @@ //查询诉求流转记录 List<ComplaintFlow> complaintFlows = complaintFlowService.lambdaQuery() .eq(ComplaintFlow::getComplaintId, id) - .orderByAsc(ComplaintFlow::getCreateTime) + .orderByAsc(ComplaintFlow::getSort) .list(); complaintVO.setComplaintFlows(complaintFlows); //查询评价 ComplaintComment comment = complaintCommentService.lambdaQuery().eq(ComplaintComment::getComplaintId, id).last("LIMIT 1").one(); complaintVO.setComplaintComment(comment); + ArrayList<String> voiceFileList = new ArrayList<>(); + String voiceFile = complaint.getVoiceFile(); + if(StringUtils.isNotEmpty(voiceFile)){ + for (String file :voiceFile.split(",")) { + voiceFileList.add(file); + } + } + + complaintVO.setVoiceFileList(voiceFileList); return complaintVO; } @@ -1134,11 +1211,12 @@ response.setHeader("Content-disposition", "attachment;filename*=utf-8''" + fileName + ".xlsx"); EasyExcel.write(response.getOutputStream(), ComplaintExcel.class) .sheet("诉求数据") + .registerWriteHandler(new AutoColumnWidthStrategy()) .doWrite(complaintExcels); } @Override - public void downloadFile(Long id, Integer type) throws IOException { + public String downloadFile(Long id, Integer type, SystemUserVo loginUserInfo) throws IOException { Complaint complaint = baseMapper.getDetailBg(id); if (Objects.isNull(complaint)) { throw new ServiceException("该诉求不存在"); @@ -1193,7 +1271,9 @@ case 2: fileName = "question_handle.docx"; if (Objects.nonNull(partyMember)) { - community = community + "-" + partyMember.getServiceTarget(); + if (StringUtil.isNotBlank(partyMember.getServiceTarget())) { + community = community + "-" + partyMember.getServiceTarget(); + } } reportType = complaint.getCompletionUserLevel(); break; @@ -1215,7 +1295,9 @@ map.put("problemType", complaint.getProblemType()); map.put("descriptionContent", complaint.getDescriptionContent()); map.put("reportType", reportType == null ? "" : ReportTypeEnum.getDescriptionByCode(reportType)); - map.put("partyOrganization", Objects.nonNull(partyMember) ? partyMember.getPartyOrganization() : ""); + if (Objects.nonNull(partyMember)) { + map.put("partyOrganization", StringUtil.isNotBlank(partyMember.getPartyOrganization()) ? partyMember.getPartyOrganization() : ""); + } map.put("name", complaint.getName()); map.put("contactNumber", complaint.getContactNumber()); map.put("nickname", complaint.getReportUserName()); @@ -1231,19 +1313,21 @@ } // 在文本中直接使用换行符 map.put("complaintProgress", sb.toString()); - map.put("status", ProcessStatusEnum.getDescriptionByCode(complaint.getStatus())); + map.put("status", ComplaintExportEnum.getEnumByCode(complaint.getStatus()).getDesc()); if (2 == type) { //查询诉求评价 ComplaintComment complaintComment = complaintCommentService.lambdaQuery().eq(ComplaintComment::getComplaintId, id).last("LIMIT 1").one(); if (Objects.nonNull(complaintComment)) { - map.put("rateStr", RateEnum.getEnumByCode(complaintComment.getRate())); + map.put("rateStr", RateEnum.getEnumByCode(complaintComment.getRate()).getDesc()); } + //map.put("departmentLevel", ReportTypeEnum.getDescriptionByCode(loginUserInfo.getAccountLevel()) + "级"); } response.setContentType("application/octet-stream"); String fileNameEncode = URLEncoder.encode(fileName, "UTF-8").replaceAll("\\+", "%20"); response.setHeader("Content-disposition", "attachment;filename=\"" + fileNameEncode + ".docx" + "\""); InputStream resourceAsStream = this.getClass().getResourceAsStream("/template/" + fileName); XWPFTemplate.compile(resourceAsStream).render(map).writeAndClose(response.getOutputStream()); + return complaint.getName(); } -- Gitblit v1.7.1