he2802 3 年 前
コミット
4f67306544

+ 7 - 3
zhongzheng-admin/src/main/java/com/zhongzheng/controller/base/UserProfileController.java

@@ -10,6 +10,7 @@ import cn.hutool.core.lang.Validator;
 import com.zhongzheng.common.core.domain.model.LoginUser;
 import com.zhongzheng.common.utils.ServletUtils;
 import com.zhongzheng.framework.web.service.TokenService;
+import com.zhongzheng.modules.base.vo.UserProfileExportGaiVo;
 import com.zhongzheng.modules.base.vo.UserProfileExportVo;
 import com.zhongzheng.modules.grade.vo.ClassPeriodStudentExportVo;
 import com.zhongzheng.modules.user.bo.UserQueryBo;
@@ -113,7 +114,7 @@ public class UserProfileController extends BaseController {
     @PreAuthorize("@ss.hasPermi('system:profile:export')")
     @Log(title = "客户端用户", businessType = BusinessType.EXPORT)
     @GetMapping("/export")
-    public AjaxResult<UserProfileExportVo> export(UserProfileQueryBo bo) {
+    public AjaxResult<Map<String,Object>> export(UserProfileQueryBo bo) {
         String fileName = "";
         if(Validator.isEmpty(bo.getStatus())){
             bo.setStatus(new ArrayList<Integer>(Arrays.asList(0)));
@@ -139,7 +140,8 @@ public class UserProfileController extends BaseController {
             bo.getStatus().remove(0);
             bo.setStatus(bo.getStatus());
         }
-        List<UserProfileExportVo> list = iUserProfileService.export(bo);
+        Map<String,Object> map = iUserProfileService.export(bo);
+        List<UserProfileExportVo> list = (List<UserProfileExportVo>)map.get("list");
         ExcelUtil<UserProfileExportVo> util = new ExcelUtil<UserProfileExportVo>(UserProfileExportVo.class);
 
         String timeStr= LocalDateTime.now().format(DateTimeFormatter.ofPattern("yyyy-MM-dd"));
@@ -153,7 +155,9 @@ public class UserProfileController extends BaseController {
         deptExportMap.put("data", list);
         List<Map<String, Object>> sheetsList = new ArrayList<>();
         sheetsList.add(deptExportMap);
-        return util.exportEasyExcel(sheetsList, "填写资料审核-"+fileName+"-学员数据-"+timeStr);
+        map.put("excel",util.exportEasyExcel(sheetsList, "填写资料审核-"+fileName+"-学员数据-"+timeStr));
+        map.remove("list");
+        return AjaxResult.success(map);
     }
 
     /*@ApiOperation("审核资料测试")

+ 6 - 3
zhongzheng-admin/src/main/java/com/zhongzheng/controller/base/UserProfileStampController.java

@@ -102,7 +102,7 @@ public class UserProfileStampController extends BaseController {
     @PreAuthorize("@ss.hasPermi('system:profile:export')")
     @Log(title = "客户端用户", businessType = BusinessType.EXPORT)
     @GetMapping("/export")
-    public AjaxResult<UserProfileExportGaiVo> export(UserProfileQueryBo bo) {
+    public AjaxResult<Map<String,Object>> export(UserProfileQueryBo bo) {
         String fileName = "";
         if(bo.getStatus().get(0)==0){
             fileName="全部";
@@ -123,7 +123,8 @@ public class UserProfileStampController extends BaseController {
             bo.getStatus().remove(0);
             bo.setStatus(bo.getStatus());
         }
-        List<UserProfileExportGaiVo> list = iUserProfileService.exportPo(bo);
+        Map<String,Object> map = iUserProfileService.exportPo(bo);
+        List<UserProfileExportGaiVo> list = (List<UserProfileExportGaiVo>)map.get("list");
         ExcelUtil<UserProfileExportGaiVo> util = new ExcelUtil<UserProfileExportGaiVo>(UserProfileExportGaiVo.class);
 
         String timeStr= LocalDateTime.now().format(DateTimeFormatter.ofPattern("yyyy-MM-dd"));
@@ -137,6 +138,8 @@ public class UserProfileStampController extends BaseController {
         deptExportMap.put("data", list);
         List<Map<String, Object>> sheetsList = new ArrayList<>();
         sheetsList.add(deptExportMap);
-        return util.exportEasyExcel(sheetsList, "填写盖章审核-"+fileName+"-学员数据-"+timeStr);
+        map.put("excel",util.exportEasyExcel(sheetsList, "填写盖章审核-"+fileName+"-学员数据-"+timeStr));
+        map.remove("list");
+        return AjaxResult.success(map);
     }
 }

+ 24 - 5
zhongzheng-common/src/main/java/com/zhongzheng/common/utils/file/FileUtils.java

@@ -2,16 +2,18 @@ package com.zhongzheng.common.utils.file;
 
 import cn.hutool.core.util.ArrayUtil;
 import cn.hutool.core.util.StrUtil;
+import com.zhongzheng.common.config.RuoYiConfig;
 
 import javax.servlet.http.HttpServletRequest;
 import javax.servlet.http.HttpServletResponse;
 import java.io.*;
 import java.net.URLEncoder;
 import java.nio.charset.StandardCharsets;
+import java.util.UUID;
 
 /**
  * 文件处理工具类
- * 
+ *
  * @author zhongzheng
  */
 public class FileUtils extends org.apache.commons.io.FileUtils
@@ -20,7 +22,7 @@ public class FileUtils extends org.apache.commons.io.FileUtils
 
     /**
      * 输出指定文件的byte数组
-     * 
+     *
      * @param filePath 文件路径
      * @param os 输出流
      * @return
@@ -76,7 +78,7 @@ public class FileUtils extends org.apache.commons.io.FileUtils
 
     /**
      * 删除文件
-     * 
+     *
      * @param filePath 文件
      * @return
      */
@@ -95,7 +97,7 @@ public class FileUtils extends org.apache.commons.io.FileUtils
 
     /**
      * 文件名称验证
-     * 
+     *
      * @param filename 文件名称
      * @return true 正常 false 非法
      */
@@ -130,7 +132,7 @@ public class FileUtils extends org.apache.commons.io.FileUtils
 
     /**
      * 下载文件名重新编码
-     * 
+     *
      * @param request 请求对象
      * @param fileName 文件名
      * @return 编码后的文件名
@@ -196,4 +198,21 @@ public class FileUtils extends org.apache.commons.io.FileUtils
         String encode = URLEncoder.encode(s, StandardCharsets.UTF_8.toString());
         return encode.replaceAll("\\+", "%20");
     }
+
+    public static String encodingZipFilename(String prefix)
+    {
+        String  filename = prefix+"_"+ UUID.randomUUID().toString() + ".zip";
+        return filename;
+    }
+
+    public static String getZipAbsoluteFile(String filename)
+    {
+        String downloadPath = RuoYiConfig.getDownloadPath() + filename;
+        File desc = new File(downloadPath);
+        if (!desc.getParentFile().exists())
+        {
+            desc.getParentFile().mkdirs();
+        }
+        return downloadPath;
+    }
 }

+ 3 - 0
zhongzheng-system/src/main/java/com/zhongzheng/modules/alioss/service/OssService.java

@@ -10,6 +10,7 @@ import org.springframework.web.multipart.MultipartFile;
 import javax.servlet.http.HttpServletRequest;
 import java.io.FileNotFoundException;
 import java.io.InputStream;
+import java.util.List;
 import java.util.Map;
 import java.util.zip.ZipOutputStream;
 
@@ -27,4 +28,6 @@ public interface OssService {
     void closeClient();
 
     void zipPeopleDownload(ClassPeriodStudentExportVo vo, ZipOutputStream outStream);
+
+    void zipCommonDownload(List<String> fileList, ZipOutputStream zipOut, String dir);
 }

+ 11 - 0
zhongzheng-system/src/main/java/com/zhongzheng/modules/alioss/service/impl/OssServiceImpl.java

@@ -340,6 +340,12 @@ public class OssServiceImpl implements OssService {
             return;
         }
         for (String filePath : fileList) {
+            if(Validator.isEmpty(filePath)){
+                continue;
+            }
+            if(filePath.indexOf("?")!=-1){
+                filePath = filePath.substring(0,filePath.indexOf("?"));
+            }
             try (InputStream in = getStreamByObject(filePath)) {
                 zipOut.putNextEntry(new ZipEntry(getFileName(filePath,dir)));
                 byte[] bytes = new byte[1024];
@@ -381,4 +387,9 @@ public class OssServiceImpl implements OssService {
         zipFile(listInfo, outStream,vo.getRealName()+"-"+vo.getIdCard()+"-"+vo.getGradeId()+"/"+"资料照片");  //
     }
 
+    @Override
+    public void zipCommonDownload(List<String> fileList, ZipOutputStream zipOut,String dir) {
+        zipFile(fileList, zipOut,dir);
+    }
+
 }

+ 3 - 2
zhongzheng-system/src/main/java/com/zhongzheng/modules/base/service/IUserProfileService.java

@@ -15,6 +15,7 @@ import java.io.FileNotFoundException;
 import java.io.IOException;
 import java.util.Collection;
 import java.util.List;
+import java.util.Map;
 
 /**
  * 填写资料审核Service接口
@@ -66,7 +67,7 @@ public interface IUserProfileService extends IService<UserProfile> {
 
 	List<UserProfileVo> listRecord(UserProfileQueryBo bo);
 
-	List<UserProfileExportVo> export(UserProfileQueryBo bo);
+	Map<String,Object> export(UserProfileQueryBo bo);
 
-	List<UserProfileExportGaiVo> exportPo(UserProfileQueryBo bo);
+	Map<String,Object> exportPo(UserProfileQueryBo bo);
 }

+ 231 - 181
zhongzheng-system/src/main/java/com/zhongzheng/modules/base/service/impl/UserProfileServiceImpl.java

@@ -15,10 +15,13 @@ import com.fasterxml.jackson.databind.exc.InvalidFormatException;
 import com.openhtmltopdf.swing.Java2DRenderer;
 import com.openhtmltopdf.util.FSImageWriter;
 import com.zhongzheng.common.annotation.DataScope;
+import com.zhongzheng.common.core.domain.AjaxResult;
 import com.zhongzheng.common.core.domain.model.LoginUser;
+import com.zhongzheng.common.exception.CustomException;
 import com.zhongzheng.common.utils.DateUtils;
 import com.zhongzheng.common.utils.SecurityUtils;
 import com.zhongzheng.common.utils.ServletUtils;
+import com.zhongzheng.common.utils.file.FileUtils;
 import com.zhongzheng.modules.alioss.bo.OssRequest;
 import com.zhongzheng.modules.alioss.service.impl.OssServiceImpl;
 import com.zhongzheng.modules.alisms.service.IAliSmsService;
@@ -72,6 +75,7 @@ import java.net.URL;
 import java.util.*;
 import java.util.List;
 import java.util.stream.Collectors;
+import java.util.zip.ZipOutputStream;
 
 /**
  * 填写资料审核Service业务层处理
@@ -119,7 +123,7 @@ public class UserProfileServiceImpl extends ServiceImpl<UserProfileMapper, UserP
     private String commitmentFailsCode;
 
     @Override
-    public UserProfileVo queryById(Long id){
+    public UserProfileVo queryById(Long id) {
         UserProfileQueryBo userProfileQueryBo = new UserProfileQueryBo();
         userProfileQueryBo.setId(id);
         UserProfileVo userProfileVo = baseMapper.selectUserProfile(userProfileQueryBo).get(0);
@@ -133,19 +137,19 @@ public class UserProfileServiceImpl extends ServiceImpl<UserProfileMapper, UserP
     }
 
     /**
-    * 实体类转化成视图对象
-    *
-    * @param collection 实体类集合
-    * @return
-    */
+     * 实体类转化成视图对象
+     *
+     * @param collection 实体类集合
+     * @return
+     */
     private List<UserProfileVo> entity2Vo(Collection<UserProfile> collection) {
         List<UserProfileVo> voList = collection.stream()
                 .map(any -> BeanUtil.toBean(any, UserProfileVo.class))
                 .collect(Collectors.toList());
         if (collection instanceof Page) {
-            Page<UserProfile> page = (Page<UserProfile>)collection;
+            Page<UserProfile> page = (Page<UserProfile>) collection;
             Page<UserProfileVo> pageVo = new Page<>();
-            BeanUtil.copyProperties(page,pageVo);
+            BeanUtil.copyProperties(page, pageVo);
             pageVo.addAll(voList);
             voList = pageVo;
         }
@@ -172,7 +176,7 @@ public class UserProfileServiceImpl extends ServiceImpl<UserProfileMapper, UserP
         UserProfileVo userProfileVo = this.queryById(bo.getId());
 
         //新增待审的资料填写
-        UserProfile addProfile = BeanUtil.toBean(bo,UserProfile.class);
+        UserProfile addProfile = BeanUtil.toBean(bo, UserProfile.class);
         addProfile.setCreateTime(DateUtils.getNowTime());
         addProfile.setUpdateTime(DateUtils.getNowTime());
         addProfile.setStatus(3);
@@ -194,13 +198,13 @@ public class UserProfileServiceImpl extends ServiceImpl<UserProfileMapper, UserP
      *
      * @param entity 实体类数据
      */
-    private void validEntityBeforeSave(UserProfile entity){
+    private void validEntityBeforeSave(UserProfile entity) {
         //TODO 做一些数据校验,如唯一约束
     }
 
     @Override
     public Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid) {
-        if(isValid){
+        if (isValid) {
             //TODO 做一些业务上的校验,判断是否需要校验
         }
         return this.removeByIds(ids);
@@ -214,12 +218,12 @@ public class UserProfileServiceImpl extends ServiceImpl<UserProfileMapper, UserP
         userProfileQueryBo.setTypeStatus(1L);
         UserProfileVo info = baseMapper.getInfo(userProfileQueryBo);
         //第一种方式
-        Map<String, String> maps = JSONObject.parseObject(info.getKeyValue(),Map.class);
+        Map<String, String> maps = JSONObject.parseObject(info.getKeyValue(), Map.class);
 
  /*       TemplateEngine engine = TemplateUtil.createEngine(new TemplateConfig("templates", TemplateConfig.ResourceMode.CLASSPATH));
         Template template = engine.getTemplate("word.ftl");*/
         //给模板绑定数据
-        Calendar rightNow= Calendar.getInstance();
+        Calendar rightNow = Calendar.getInstance();
         Map<String, Object> bindingMap = new HashMap<>();
         bindingMap.put("username", JSONObject.parseObject(String.valueOf(maps.get("name")), UserProfileFit.class).getValue());
         bindingMap.put("s", JSONObject.parseObject(String.valueOf(maps.get("sex")), UserProfileFit.class).getValue());
@@ -231,22 +235,22 @@ public class UserProfileServiceImpl extends ServiceImpl<UserProfileMapper, UserP
         bindingMap.put("major", JSONObject.parseObject(String.valueOf(maps.get("major")), UserProfileFit.class).getValue());
         bindingMap.put("cname", JSONObject.parseObject(String.valueOf(maps.get("unit_contact")), UserProfileFit.class).getValue());
         bindingMap.put("cphone", JSONObject.parseObject(String.valueOf(maps.get("unit_tel")), UserProfileFit.class).getValue());
-        bindingMap.put("image",  ALIYUN_OSS_ENDPOINT+"/"+JSONObject.parseObject(String.valueOf(maps.get("commitment_electr_signature")), UserProfileFit.class).getValue());
+        bindingMap.put("image", ALIYUN_OSS_ENDPOINT + "/" + JSONObject.parseObject(String.valueOf(maps.get("commitment_electr_signature")), UserProfileFit.class).getValue());
         bindingMap.put("y", Convert.toStr(rightNow.get(Calendar.YEAR)));
-        bindingMap.put("m", rightNow.get(Calendar.MONTH)+1);
+        bindingMap.put("m", rightNow.get(Calendar.MONTH) + 1);
         bindingMap.put("d", rightNow.get(Calendar.DAY_OF_MONTH));
         bindingMap.put("time", JSONObject.parseObject(String.valueOf(maps.get("graduation_time")), UserProfileFit.class).getValue());
         bindingMap.put("year", JSONObject.parseObject(String.valueOf(maps.get("working_years")), UserProfileFit.class).getValue());
-        File touch = FileUtil.touch(ZHONGZHENG_PROFILE+"word.html");
+        File touch = FileUtil.touch(ZHONGZHENG_PROFILE + "word.html");
         //默认freemake配置
         Configuration configuration = new Configuration();
         configuration.setDefaultEncoding("UTF-8");
         configuration.setClassForTemplateLoading(this.getClass(), "/templates");
         Template template = configuration.getTemplate("wordPhone.ftl");
-        Writer out = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(touch),"UTF-8"));
+        Writer out = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(touch), "UTF-8"));
         try {
             //写入数据
-            template.process(bindingMap,out);
+            template.process(bindingMap, out);
             out.flush();
             out.close();
 
@@ -258,11 +262,11 @@ public class UserProfileServiceImpl extends ServiceImpl<UserProfileMapper, UserP
         final BufferedImage img = renderer.getImage();
         final FSImageWriter imageWriter = new FSImageWriter();
         imageWriter.setWriteCompressionQuality(1.0f);
-        imageWriter.write(img, ZHONGZHENG_PROFILE+"wordJpg.jpg");//输出路径
+        imageWriter.write(img, ZHONGZHENG_PROFILE + "wordJpg.jpg");//输出路径
 
         OssRequest ossRequest = new OssRequest();
-        FileInputStream fileInputStream = new FileInputStream(ZHONGZHENG_PROFILE+"wordJpg.jpg");
-        MultipartFile multipartFile = new MockMultipartFile(ZHONGZHENG_PROFILE+"wordJpg.jpg", ZHONGZHENG_PROFILE+"wordJpg.jpg",
+        FileInputStream fileInputStream = new FileInputStream(ZHONGZHENG_PROFILE + "wordJpg.jpg");
+        MultipartFile multipartFile = new MockMultipartFile(ZHONGZHENG_PROFILE + "wordJpg.jpg", ZHONGZHENG_PROFILE + "wordJpg.jpg",
                 ContentType.APPLICATION_OCTET_STREAM.toString(), fileInputStream);
         ossRequest.setFile(multipartFile);
         ossRequest.setImageStatus(6);
@@ -280,16 +284,16 @@ public class UserProfileServiceImpl extends ServiceImpl<UserProfileMapper, UserP
         userProfileQueryBo.setTypeStatus(1L);
         UserProfileVo info = baseMapper.getInfo(userProfileQueryBo);
         System.out.println(info);
-        if(Validator.isEmpty(info)){
+        if (Validator.isEmpty(info)) {
             return "";
         }
         //第一种方式
-        Map<String, String> maps = JSONObject.parseObject(info.getKeyValue(),Map.class);
+        Map<String, String> maps = JSONObject.parseObject(info.getKeyValue(), Map.class);
 
  /*       TemplateEngine engine = TemplateUtil.createEngine(new TemplateConfig("templates", TemplateConfig.ResourceMode.CLASSPATH));
         Template template = engine.getTemplate("word.ftl");*/
         //给模板绑定数据
-        Calendar rightNow= Calendar.getInstance();
+        Calendar rightNow = Calendar.getInstance();
         Map<String, Object> bindingMap = new HashMap<>();
         bindingMap.put("name", JSONObject.parseObject(String.valueOf(maps.get("name")), UserProfileFit.class).getValue());
         bindingMap.put("s", JSONObject.parseObject(String.valueOf(maps.get("sex")), UserProfileFit.class).getValue());
@@ -301,13 +305,13 @@ public class UserProfileServiceImpl extends ServiceImpl<UserProfileMapper, UserP
         bindingMap.put("major", JSONObject.parseObject(String.valueOf(maps.get("major")), UserProfileFit.class).getValue());
         bindingMap.put("cname", JSONObject.parseObject(String.valueOf(maps.get("unit_contact")), UserProfileFit.class).getValue());
         bindingMap.put("cphone", JSONObject.parseObject(String.valueOf(maps.get("unit_tel")), UserProfileFit.class).getValue());
-        bindingMap.put("image",  ALIYUN_OSS_ENDPOINT+"/"+JSONObject.parseObject(String.valueOf(maps.get("commitment_electr_signature")), UserProfileFit.class).getValue());
+        bindingMap.put("image", ALIYUN_OSS_ENDPOINT + "/" + JSONObject.parseObject(String.valueOf(maps.get("commitment_electr_signature")), UserProfileFit.class).getValue());
         bindingMap.put("y", Convert.toStr(rightNow.get(Calendar.YEAR)));
-        bindingMap.put("m", rightNow.get(Calendar.MONTH)+1);
+        bindingMap.put("m", rightNow.get(Calendar.MONTH) + 1);
         bindingMap.put("d", rightNow.get(Calendar.DAY_OF_MONTH));
         bindingMap.put("time", JSONObject.parseObject(String.valueOf(maps.get("graduation_time")), UserProfileFit.class).getValue());
         bindingMap.put("year", JSONObject.parseObject(String.valueOf(maps.get("working_years")), UserProfileFit.class).getValue());
-        File touch = FileUtil.touch(ZHONGZHENG_PROFILE+"word.html");
+        File touch = FileUtil.touch(ZHONGZHENG_PROFILE + "word.html");
         //默认freemake配置
         Configuration configuration = new Configuration();
         configuration.setDefaultEncoding("UTF-8");
@@ -315,12 +319,12 @@ public class UserProfileServiceImpl extends ServiceImpl<UserProfileMapper, UserP
 
         configuration.setClassForTemplateLoading(this.getClass(), "/templates");
         Template template = configuration.getTemplate("wordPhone.ftl");
-    //    File outFile = new File(ZHONGZHENG_PROFILE+"wordJpg.doc"); //导出文件
-        Writer out = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(touch),"UTF-8"));
-    //    Writer out = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(outFile),"UTF-8"));
+        //    File outFile = new File(ZHONGZHENG_PROFILE+"wordJpg.doc"); //导出文件
+        Writer out = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(touch), "UTF-8"));
+        //    Writer out = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(outFile),"UTF-8"));
         try {
             //写入数据
-            template.process(bindingMap,out);
+            template.process(bindingMap, out);
             out.flush();
             out.close();
 
@@ -341,11 +345,11 @@ public class UserProfileServiceImpl extends ServiceImpl<UserProfileMapper, UserP
         final BufferedImage img = renderer.getImage();
         final FSImageWriter imageWriter = new FSImageWriter();
         imageWriter.setWriteCompressionQuality(1.0f);
-        imageWriter.write(img, ZHONGZHENG_PROFILE+"wordJpg.jpg");//输出路径
+        imageWriter.write(img, ZHONGZHENG_PROFILE + "wordJpg.jpg");//输出路径
 
         OssRequest ossRequest = new OssRequest();
-        FileInputStream fileInputStream = new FileInputStream(ZHONGZHENG_PROFILE+"wordJpg.jpg");
-        MultipartFile multipartFile = new MockMultipartFile(ZHONGZHENG_PROFILE+"wordJpg.jpg", ZHONGZHENG_PROFILE+"wordJpg.jpg",
+        FileInputStream fileInputStream = new FileInputStream(ZHONGZHENG_PROFILE + "wordJpg.jpg");
+        MultipartFile multipartFile = new MockMultipartFile(ZHONGZHENG_PROFILE + "wordJpg.jpg", ZHONGZHENG_PROFILE + "wordJpg.jpg",
                 ContentType.APPLICATION_OCTET_STREAM.toString(), fileInputStream);
         ossRequest.setFile(multipartFile);
         ossRequest.setImageStatus(6);
@@ -361,12 +365,17 @@ public class UserProfileServiceImpl extends ServiceImpl<UserProfileMapper, UserP
 
     @Override
     @Transactional(rollbackFor = Exception.class)
-    public boolean updateAuditByEditBo(UserProfileEditBo bo,LoginUser loginUser) {
-        UserProfile update = BeanUtil.toBean(bo,UserProfile.class);
+    public boolean updateAuditByEditBo(UserProfileEditBo bo, LoginUser loginUser) {
+        if(Validator.isNotEmpty(bo.getKeyValue())){
+            if(bo.getKeyValue().indexOf("http")!=-1){
+                throw new CustomException("图片地址错误");
+            }
+        }
+        UserProfile update = BeanUtil.toBean(bo, UserProfile.class);
         UserProfileVo userProfileVo1 = this.queryById(bo.getId());
         //查询此人审核资料是否有权限
-        if(!loginUser.getUser().isAdmin()){
-            if (baseMapper.selectCountProfile(loginUser.getUser().getUserId(),userProfileVo1.getGoodsId()) < 1){
+        if (!loginUser.getUser().isAdmin()) {
+            if (baseMapper.selectCountProfile(loginUser.getUser().getUserId(), userProfileVo1.getGoodsId()) < 1) {
                 throw new IllegalArgumentException("您没有审核权限");
             }
         }
@@ -375,12 +384,12 @@ public class UserProfileServiceImpl extends ServiceImpl<UserProfileMapper, UserP
         update.setUpdateTime(DateUtils.getNowTime());
         update.setAuditTime(DateUtils.getNowTime());
         update.setChangeStatus(1);
-
         //审核资料发送消息
         sendAuidit(update);
         if (update.getStatus().equals(1)) {
             //审核通过同步身份证到用户信息
             getUserPicInfo(update);
+
         }
         //审核承诺书发送消息
         sendAuiditSMS(update);
@@ -391,33 +400,33 @@ public class UserProfileServiceImpl extends ServiceImpl<UserProfileMapper, UserP
     /**
      * 同步身份证到用户信息
      */
-    private void getUserPicInfo(UserProfile bo){
+    private void getUserPicInfo(UserProfile bo) {
         String keyValue = bo.getKeyValue();
-        if(Validator.isNotEmpty(keyValue)){
-            Map<String, String> maps = JSONObject.parseObject(keyValue,Map.class);
-            String recent_photos,idcard_face_photo,idcard_national_photo = null;
+        if (Validator.isNotEmpty(keyValue)) {
+            Map<String, String> maps = JSONObject.parseObject(keyValue, Map.class);
+            String recent_photos, idcard_face_photo, idcard_national_photo = null;
             LambdaUpdateWrapper<User> objectLambdaUpdateWrapper = Wrappers.lambdaUpdate();
             objectLambdaUpdateWrapper.eq(User::getUserId, bo.getUserId());
-            if(maps.containsKey("recent_photos")){
+            if (maps.containsKey("recent_photos")) {
                 recent_photos = JSONObject.parseObject(String.valueOf(maps.get("recent_photos")), UserProfileFit.class).getValue();
                 objectLambdaUpdateWrapper.set(User::getOneInchPhotos, recent_photos);
             }
-            if(maps.containsKey("idcard_face_photo")){
+            if (maps.containsKey("idcard_face_photo")) {
                 idcard_face_photo = JSONObject.parseObject(String.valueOf(maps.get("idcard_face_photo")), UserProfileFit.class).getValue();
                 objectLambdaUpdateWrapper.set(User::getIdCardImg1, idcard_face_photo);
             }
-            if(maps.containsKey("idcard_national_photo")){
+            if (maps.containsKey("idcard_national_photo")) {
                 idcard_national_photo = JSONObject.parseObject(String.valueOf(maps.get("idcard_national_photo")), UserProfileFit.class).getValue();
                 objectLambdaUpdateWrapper.set(User::getIdCardImg2, idcard_national_photo);
             }
-            objectLambdaUpdateWrapper.set(User::getUpdateTime,DateUtils.getNowTime());
+            objectLambdaUpdateWrapper.set(User::getUpdateTime, DateUtils.getNowTime());
             iUserService.update(null, objectLambdaUpdateWrapper);
         }
     }
 
     private void sendAuiditSMS(UserProfile bo) {
         UserProfileVo userProfileVo = this.queryById(bo.getId());
-        Long gradeId = baseMapper.selectGrade(userProfileVo.getUserId(),userProfileVo.getGoodsId());
+        Long gradeId = baseMapper.selectGrade(userProfileVo.getUserId(), userProfileVo.getGoodsId());
         if (bo.getStatus().equals(1)) {
             InformRemindVo informRemindVo = informRemindService.queryById(23L);
             //站内信有无启用,启用发送
@@ -434,11 +443,11 @@ public class UserProfileServiceImpl extends ServiceImpl<UserProfileMapper, UserP
                 informUserAddBo.setGoodsId(userProfileVo.getGoodsId());
                 informUserAddBo.setGradeId(gradeId);
                 GoodsVo goodsVo1 = iGoodsService.queryById(userProfileVo.getGoodsId());
-                informUserAddBo.setText("尊敬的用户:您上传"+goodsVo1.getGoodsName()+"课程的承诺书审核成功");
+                informUserAddBo.setText("尊敬的用户:您上传" + goodsVo1.getGoodsName() + "课程的承诺书审核成功");
                 iInformUserService.insertByAddBo(informUserAddBo);
             }
             //短信有无启用,启用发送
-            if (informRemindVo.getNoteStatus().equals(1)){
+            if (informRemindVo.getNoteStatus().equals(1)) {
                 InformUserAddBo informUserAddBo = new InformUserAddBo();
                 informUserAddBo.setUserId(userProfileVo.getUserId());
                 informUserAddBo.setSendTime(DateUtils.getNowTime());
@@ -450,14 +459,14 @@ public class UserProfileServiceImpl extends ServiceImpl<UserProfileMapper, UserP
                 informUserAddBo.setRemind("资料审核通过通知");
                 informUserAddBo.setGoodsId(userProfileVo.getGoodsId());
                 GoodsVo goodsVo1 = iGoodsService.queryById(userProfileVo.getGoodsId());
-                informUserAddBo.setText("尊敬的用户:您上传"+goodsVo1.getGoodsName()+"课程的承诺书审核成功");
+                informUserAddBo.setText("尊敬的用户:您上传" + goodsVo1.getGoodsName() + "课程的承诺书审核成功");
                 iInformUserService.insertByAddBo(informUserAddBo);
                 UserVo userVo = iUserService.queryById(userProfileVo.getUserId());
                 Map<String, Object> param = new HashMap<>();
                 param.put("goods", goodsVo1.getGoodsName());
                 IAliSmsService.sendInformSms(userVo.getTelphone(), JSON.toJSONString(param), commitmentCode);
             }
-        }else {
+        } else {
             InformRemindVo informRemindTwoVo = informRemindService.queryById(24L);
             //站内信有无启用,启用发送
             if (informRemindTwoVo.getWayStatus().equals(1)) {
@@ -473,11 +482,11 @@ public class UserProfileServiceImpl extends ServiceImpl<UserProfileMapper, UserP
                 informUserAddBo.setGoodsId(userProfileVo.getGoodsId());
                 informUserAddBo.setGradeId(gradeId);
                 GoodsVo goodsVo1 = iGoodsService.queryById(userProfileVo.getGoodsId());
-                informUserAddBo.setText("尊敬的用户:您上传"+goodsVo1.getGoodsName()+"课程的承诺书审核不通过,请重新完善吧");
+                informUserAddBo.setText("尊敬的用户:您上传" + goodsVo1.getGoodsName() + "课程的承诺书审核不通过,请重新完善吧");
                 iInformUserService.insertByAddBo(informUserAddBo);
             }
             //短信有无启用,启用发送
-            if (informRemindTwoVo.getNoteStatus().equals(1)){
+            if (informRemindTwoVo.getNoteStatus().equals(1)) {
                 InformUserAddBo informUserAddBo = new InformUserAddBo();
                 informUserAddBo.setUserId(userProfileVo.getUserId());
                 informUserAddBo.setSendTime(DateUtils.getNowTime());
@@ -489,7 +498,7 @@ public class UserProfileServiceImpl extends ServiceImpl<UserProfileMapper, UserP
                 informUserAddBo.setRemind("资料审核不通过通知");
                 informUserAddBo.setGoodsId(userProfileVo.getGoodsId());
                 GoodsVo goodsVo1 = iGoodsService.queryById(userProfileVo.getGoodsId());
-                informUserAddBo.setText("尊敬的用户:您上传"+goodsVo1.getGoodsName()+"课程的承诺书审核不通过,请重新完善吧");
+                informUserAddBo.setText("尊敬的用户:您上传" + goodsVo1.getGoodsName() + "课程的承诺书审核不通过,请重新完善吧");
                 iInformUserService.insertByAddBo(informUserAddBo);
                 UserVo userVo = iUserService.queryById(userProfileVo.getUserId());
                 Map<String, Object> param = new HashMap<>();
@@ -502,7 +511,7 @@ public class UserProfileServiceImpl extends ServiceImpl<UserProfileMapper, UserP
     private void sendAuidit(UserProfile bo) {
         UserProfileVo userProfileVo = this.queryById(bo.getId());
         //查询所在班级
-        Long gradeId = baseMapper.selectGrade(userProfileVo.getUserId(),userProfileVo.getGoodsId());
+        Long gradeId = baseMapper.selectGrade(userProfileVo.getUserId(), userProfileVo.getGoodsId());
         if (bo.getStatus().equals(1)) {
             InformRemindVo informRemindVo = informRemindService.queryById(3L);
             //站内信有无启用,启用发送
@@ -519,11 +528,11 @@ public class UserProfileServiceImpl extends ServiceImpl<UserProfileMapper, UserP
                 informUserAddBo.setGoodsId(userProfileVo.getGoodsId());
                 informUserAddBo.setGradeId(gradeId);
                 GoodsVo goodsVo1 = iGoodsService.queryById(userProfileVo.getGoodsId());
-                informUserAddBo.setText("尊敬的用户:您填写的"+goodsVo1.getGoodsName()+"课程报名信息审核成功,请尽快去学习吧");
+                informUserAddBo.setText("尊敬的用户:您填写的" + goodsVo1.getGoodsName() + "课程报名信息审核成功,请尽快去学习吧");
                 iInformUserService.insertByAddBo(informUserAddBo);
             }
             //短信有无启用,启用发送
-            if (informRemindVo.getNoteStatus().equals(1)){
+            if (informRemindVo.getNoteStatus().equals(1)) {
                 InformUserAddBo informUserAddBo = new InformUserAddBo();
                 informUserAddBo.setUserId(userProfileVo.getUserId());
                 informUserAddBo.setSendTime(DateUtils.getNowTime());
@@ -542,7 +551,7 @@ public class UserProfileServiceImpl extends ServiceImpl<UserProfileMapper, UserP
                 param.put("goods", goodsVo1.getGoodsName());
                 IAliSmsService.sendInformSms(userVo.getTelphone(), JSON.toJSONString(param), materialReviewCode);
             }
-        }else {
+        } else {
             InformRemindVo informRemindTwoVo = informRemindService.queryById(4L);
             //站内信有无启用,启用发送
             if (informRemindTwoVo.getWayStatus().equals(1)) {
@@ -558,11 +567,11 @@ public class UserProfileServiceImpl extends ServiceImpl<UserProfileMapper, UserP
                 informUserAddBo.setGoodsId(userProfileVo.getGoodsId());
                 informUserAddBo.setGradeId(gradeId);
                 GoodsVo goodsVo1 = iGoodsService.queryById(userProfileVo.getGoodsId());
-                informUserAddBo.setText("尊敬的用户:您填写的"+goodsVo1.getGoodsName()+"课程报名信息审核不通过,请重新完善吧");
+                informUserAddBo.setText("尊敬的用户:您填写的" + goodsVo1.getGoodsName() + "课程报名信息审核不通过,请重新完善吧");
                 iInformUserService.insertByAddBo(informUserAddBo);
             }
             //短信有无启用,启用发送
-            if (informRemindTwoVo.getNoteStatus().equals(1)){
+            if (informRemindTwoVo.getNoteStatus().equals(1)) {
                 InformUserAddBo informUserAddBo = new InformUserAddBo();
                 informUserAddBo.setUserId(userProfileVo.getUserId());
                 informUserAddBo.setSendTime(DateUtils.getNowTime());
@@ -574,7 +583,7 @@ public class UserProfileServiceImpl extends ServiceImpl<UserProfileMapper, UserP
                 informUserAddBo.setRemind("报名资料审核不通过通知");
                 informUserAddBo.setGoodsId(userProfileVo.getGoodsId());
                 GoodsVo goodsVo1 = iGoodsService.queryById(userProfileVo.getGoodsId());
-                informUserAddBo.setText("尊敬的用户:您填写的"+goodsVo1.getGoodsName()+"课程报名信息审核不通过,请重新完善吧");
+                informUserAddBo.setText("尊敬的用户:您填写的" + goodsVo1.getGoodsName() + "课程报名信息审核不通过,请重新完善吧");
                 iInformUserService.insertByAddBo(informUserAddBo);
                 UserVo userVo = iUserService.queryById(userProfileVo.getUserId());
                 Map<String, Object> param = new HashMap<>();
@@ -590,118 +599,30 @@ public class UserProfileServiceImpl extends ServiceImpl<UserProfileMapper, UserP
     }
 
     @Override
-    public List<UserProfileExportVo> export(UserProfileQueryBo bo) {
+    public Map<String, Object> export(UserProfileQueryBo bo) {
         List<UserProfileVo> userProfileVos = baseMapper.selectUserProfile(bo);
         List<UserProfileExportVo> userProfileExportVos = new ArrayList<>();
-        for (UserProfileVo userProfileVo : userProfileVos) {
-            UserProfileExportVo userProfileExportVo = new UserProfileExportVo();
-            //将keyvlue转成对象
-            JsonBean jsonBean = JSON.parseObject(userProfileVo.getKeyValue(), JsonBean.class);
-
-            //赋值
-            userProfileExportVo.setGoodsName(userProfileVo.getGoodsName());
-            if (userProfileVo.getStatus().equals(1)) {
-                userProfileExportVo.setStatus("通过");
-            }
-            if (userProfileVo.getStatus().equals(2)) {
-                userProfileExportVo.setStatus("待审");
-            }
-            if (userProfileVo.getStatus().equals(3)) {
-                userProfileExportVo.setStatus("不通过");
-            }
-            userProfileExportVo.setUserAccount(userProfileVo.getUserAccount());
-            userProfileExportVo.setName(jsonBean.getName().getValue());
-            userProfileExportVo.setSex(jsonBean.getSex().getValue());
-            userProfileExportVo.setIdcard(jsonBean.getIdcard().getValue());
-            userProfileExportVo.setTelphone(jsonBean.getTelphone().getValue());
-            userProfileExportVo.setEducation(jsonBean.getEducation().getValue());
-            userProfileExportVo.setSchool(jsonBean.getSchool().getValue());
-            userProfileExportVo.setGraduation_time(DateUtil.formatDate(jsonBean.getGraduation_time().getValue()));
-            userProfileExportVo.setWork_unit(jsonBean.getWork_unit().getValue());
-            userProfileExportVo.setUnit_contact(jsonBean.getUnit_contact().getValue());
-            userProfileExportVo.setUnit_tel(jsonBean.getUnit_tel().getValue());
-            userProfileExportVo.setApply_post(jsonBean.getApply_post().getValue());
-            userProfileExportVo.setMajor(jsonBean.getMajor().getValue());
-            userProfileExportVo.setWorking_years(jsonBean.getWorking_years().getValue());
-            if (Validator.isNotEmpty(jsonBean.getRecent_photos())) {
-                userProfileExportVo.setRecent_photos(ALIYUN_OSS_ENDPOINT + "/" + jsonBean.getRecent_photos().getValue());
-            }
-
-            if (Validator.isNotEmpty(jsonBean.getIdcard_face_photo())) {
-                userProfileExportVo.setIdcard_face_photo(ALIYUN_OSS_ENDPOINT + "/" + jsonBean.getIdcard_face_photo().getValue());
-            }
-
-            if (Validator.isNotEmpty(jsonBean.getIdcard_national_photo())) {
-                userProfileExportVo.setIdcard_national_photo(ALIYUN_OSS_ENDPOINT + "/" + jsonBean.getIdcard_national_photo().getValue());
-            }
-
-            if (Validator.isNotEmpty(jsonBean.getCommitment_electr_signature())) {
-                userProfileExportVo.setCommitment_electr_signature(ALIYUN_OSS_ENDPOINT + "/" + jsonBean.getCommitment_electr_signature().getValue());
-            }
-            //查找盖章得记录
-            UserProfileQueryBo userProfileQueryBo = new UserProfileQueryBo();
-            userProfileQueryBo.setTypeStatus(2L);
-            userProfileQueryBo.setGoodsId(userProfileVo.getGoodsId());
-            userProfileQueryBo.setUserId(userProfileVo.getUserId());
-            List<UserProfileVo> userProfile = baseMapper.selectUserProfile(userProfileQueryBo);
-            if (CollectionUtils.isNotEmpty(userProfile)){
-                UserProfileVo userProfileVo1 = userProfile.get(0);
-                JsonBean jsonBean1 = JSON.parseObject(userProfileVo1.getKeyValue(), JsonBean.class);
-                if (!StringUtils.isEmpty(jsonBean1.getCommitment_seal().getValue())) {
-                    if (StringUtils.isNotBlank(jsonBean1.getCommitment_seal().getValue())) {
-                        userProfileExportVo.setCommitment_seal(ALIYUN_OSS_ENDPOINT + "/" + jsonBean1.getCommitment_seal().getValue());
-                    }
+        String filename = FileUtils.encodingZipFilename("用户盖章资料数据");
+        String zipFile = FileUtils.getZipAbsoluteFile(filename);
+        try {
+            ZipOutputStream outStream = new ZipOutputStream(new FileOutputStream(zipFile));
+            for (UserProfileVo userProfileVo : userProfileVos) {
+                UserProfileExportVo userProfileExportVo = new UserProfileExportVo();
+                //将keyvlue转成对象
+                JsonBean jsonBean = JSON.parseObject(userProfileVo.getKeyValue(), JsonBean.class);
+
+                //赋值
+                userProfileExportVo.setGoodsName(userProfileVo.getGoodsName());
+                if (userProfileVo.getStatus().equals(1)) {
+                    userProfileExportVo.setStatus("通过");
                 }
-            }
-            userProfileExportVo.setOneTime(DateUtil.formatDateTime(new Date(userProfileVo.getOneTime()*1000)));
-            userProfileExportVo.setLastTime(DateUtil.formatDateTime(new Date(userProfileVo.getLastTime()*1000)));
-            userProfileExportVo.setCreateByName(userProfileVo.getCreateByName());
-            if (userProfileVo.getAuditTime() != null) {
-                userProfileExportVo.setAuditTime(DateUtil.formatDateTime(new Date(userProfileVo.getAuditTime() * 1000)));
-            }
-            userProfileExportVos.add(userProfileExportVo);
-        }
-        return userProfileExportVos;
-    }
-
-    @Override
-    public List<UserProfileExportGaiVo> exportPo(UserProfileQueryBo bo) {
-        List<UserProfileVo> userProfileVos = baseMapper.selectUserProfile(bo);
-        List<UserProfileExportGaiVo> userProfileExportVos = new ArrayList<>();
-        for (UserProfileVo userProfileVo : userProfileVos) {
-            UserProfileExportGaiVo userProfileExportVo = new UserProfileExportGaiVo();
-            //将keyvlue转成对象
-            JsonBean jsonBean1 = JSON.parseObject(userProfileVo.getKeyValue(), JsonBean.class);
-
-            //赋值
-
-            if (!StringUtils.isEmpty(jsonBean1.getCommitment_seal().getValue())) {
-                if (StringUtils.isNotBlank(jsonBean1.getCommitment_seal().getValue())) {
-                    userProfileExportVo.setCommitment_seal(ALIYUN_OSS_ENDPOINT + "/" + jsonBean1.getCommitment_seal().getValue());
+                if (userProfileVo.getStatus().equals(2)) {
+                    userProfileExportVo.setStatus("待审");
                 }
-            }
-
-            userProfileExportVo.setGoodsName(userProfileVo.getGoodsName());
-            if (userProfileVo.getStatus().equals(1)) {
-                userProfileExportVo.setStatus("通过");
-            }
-            if (userProfileVo.getStatus().equals(2)) {
-                userProfileExportVo.setStatus("待审");
-            }
-            if (userProfileVo.getStatus().equals(3)) {
-                userProfileExportVo.setStatus("不通过");
-            }
-            userProfileExportVo.setUserAccount(userProfileVo.getUserAccount());
-
-            //查找盖章得记录
-            UserProfileQueryBo userProfileQueryBo = new UserProfileQueryBo();
-            userProfileQueryBo.setTypeStatus(1L);
-            userProfileQueryBo.setGoodsId(userProfileVo.getGoodsId());
-            userProfileQueryBo.setUserId(userProfileVo.getUserId());
-            List<UserProfileVo> userProfile = baseMapper.selectUserProfile(userProfileQueryBo);
-            if (CollectionUtils.isNotEmpty(userProfile)){
-                UserProfileVo userProfileVo1 = userProfile.get(0);
-                JsonBean jsonBean = JSON.parseObject(userProfileVo1.getKeyValue(), JsonBean.class);
+                if (userProfileVo.getStatus().equals(3)) {
+                    userProfileExportVo.setStatus("不通过");
+                }
+                userProfileExportVo.setUserAccount(userProfileVo.getUserAccount());
                 userProfileExportVo.setName(jsonBean.getName().getValue());
                 userProfileExportVo.setSex(jsonBean.getSex().getValue());
                 userProfileExportVo.setIdcard(jsonBean.getIdcard().getValue());
@@ -715,28 +636,157 @@ public class UserProfileServiceImpl extends ServiceImpl<UserProfileMapper, UserP
                 userProfileExportVo.setApply_post(jsonBean.getApply_post().getValue());
                 userProfileExportVo.setMajor(jsonBean.getMajor().getValue());
                 userProfileExportVo.setWorking_years(jsonBean.getWorking_years().getValue());
-                if (Validator.isNotEmpty(jsonBean.getRecent_photos())) {
+                List<String> fileList = new ArrayList<>();
+                if (Validator.isNotEmpty(jsonBean.getRecent_photos().getValue())) {
                     userProfileExportVo.setRecent_photos(ALIYUN_OSS_ENDPOINT + "/" + jsonBean.getRecent_photos().getValue());
+                    fileList.add(jsonBean.getRecent_photos().getValue());
                 }
-                if (Validator.isNotEmpty(jsonBean.getIdcard_face_photo())) {
+
+                if (Validator.isNotEmpty(jsonBean.getIdcard_face_photo().getValue())) {
                     userProfileExportVo.setIdcard_face_photo(ALIYUN_OSS_ENDPOINT + "/" + jsonBean.getIdcard_face_photo().getValue());
+                    fileList.add(jsonBean.getIdcard_face_photo().getValue());
                 }
-                if (Validator.isNotEmpty(jsonBean.getIdcard_national_photo())) {
+
+                if (Validator.isNotEmpty(jsonBean.getIdcard_national_photo().getValue())) {
                     userProfileExportVo.setIdcard_national_photo(ALIYUN_OSS_ENDPOINT + "/" + jsonBean.getIdcard_national_photo().getValue());
+                    fileList.add(jsonBean.getIdcard_national_photo().getValue());
                 }
-                if (Validator.isNotEmpty(jsonBean.getCommitment_electr_signature())) {
+
+                if (Validator.isNotEmpty(jsonBean.getCommitment_electr_signature().getValue())) {
                     userProfileExportVo.setCommitment_electr_signature(ALIYUN_OSS_ENDPOINT + "/" + jsonBean.getCommitment_electr_signature().getValue());
+                    fileList.add(jsonBean.getCommitment_electr_signature().getValue());
                 }
+                String dir = userProfileExportVo.getName() + "_" + userProfileExportVo.getIdcard();
+                ossService.zipCommonDownload(fileList, outStream, dir);
+                //查找盖章得记录
+                UserProfileQueryBo userProfileQueryBo = new UserProfileQueryBo();
+                userProfileQueryBo.setTypeStatus(2L);
+                userProfileQueryBo.setGoodsId(userProfileVo.getGoodsId());
+                userProfileQueryBo.setUserId(userProfileVo.getUserId());
+                List<UserProfileVo> userProfile = baseMapper.selectUserProfile(userProfileQueryBo);
+                if (CollectionUtils.isNotEmpty(userProfile)) {
+                    UserProfileVo userProfileVo1 = userProfile.get(0);
+                    JsonBean jsonBean1 = JSON.parseObject(userProfileVo1.getKeyValue(), JsonBean.class);
+                    if (!StringUtils.isEmpty(jsonBean1.getCommitment_seal().getValue())) {
+                        if (StringUtils.isNotBlank(jsonBean1.getCommitment_seal().getValue())) {
+                            userProfileExportVo.setCommitment_seal(ALIYUN_OSS_ENDPOINT + "/" + jsonBean1.getCommitment_seal().getValue());
+                        }
+                    }
+                }
+                userProfileExportVo.setOneTime(DateUtil.formatDateTime(new Date(userProfileVo.getOneTime() * 1000)));
+                userProfileExportVo.setLastTime(DateUtil.formatDateTime(new Date(userProfileVo.getLastTime() * 1000)));
+                userProfileExportVo.setCreateByName(userProfileVo.getCreateByName());
+                if (userProfileVo.getAuditTime() != null) {
+                    userProfileExportVo.setAuditTime(DateUtil.formatDateTime(new Date(userProfileVo.getAuditTime() * 1000)));
+                }
+                userProfileExportVos.add(userProfileExportVo);
             }
-            userProfileExportVo.setOneTime(DateUtil.formatDateTime(new Date(userProfileVo.getOneTime()*1000)));
-            userProfileExportVo.setLastTime(DateUtil.formatDateTime(new Date(userProfileVo.getLastTime()*1000)));
-            userProfileExportVo.setCreateByName(userProfileVo.getCreateByName());
-            if (userProfileVo.getAuditTime() != null) {
-                userProfileExportVo.setAuditTime(DateUtil.formatDateTime(new Date(userProfileVo.getAuditTime() * 1000)));
+            outStream.close();
+        } catch (IOException e) {
+            System.out.println(e.getMessage() + "压缩");
+        }
+        Map<String, Object> rs = new HashMap<>();
+        rs.put("list", userProfileExportVos);
+        rs.put("zip", AjaxResult.success(filename));
+        //List<UserProfileExportGaiVo>
+        return rs;
+    }
+
+    @Override
+    public Map<String, Object> exportPo(UserProfileQueryBo bo) {
+        List<UserProfileVo> userProfileVos = baseMapper.selectUserProfile(bo);
+        List<UserProfileExportGaiVo> userProfileExportVos = new ArrayList<>();
+        String filename = FileUtils.encodingZipFilename("用户盖章资料数据");
+        String zipFile = FileUtils.getZipAbsoluteFile(filename);
+        try {
+            ZipOutputStream outStream = new ZipOutputStream(new FileOutputStream(zipFile));
+            for (UserProfileVo userProfileVo : userProfileVos) {
+                UserProfileExportGaiVo userProfileExportVo = new UserProfileExportGaiVo();
+                //将keyvlue转成对象
+                JsonBean jsonBean1 = JSON.parseObject(userProfileVo.getKeyValue(), JsonBean.class);
+
+                //赋值
+
+                if (!StringUtils.isEmpty(jsonBean1.getCommitment_seal().getValue())) {
+                    if (StringUtils.isNotBlank(jsonBean1.getCommitment_seal().getValue())) {
+                        userProfileExportVo.setCommitment_seal(ALIYUN_OSS_ENDPOINT + "/" + jsonBean1.getCommitment_seal().getValue());
+                    }
+                }
+
+                userProfileExportVo.setGoodsName(userProfileVo.getGoodsName());
+                if (userProfileVo.getStatus().equals(1)) {
+                    userProfileExportVo.setStatus("通过");
+                }
+                if (userProfileVo.getStatus().equals(2)) {
+                    userProfileExportVo.setStatus("待审");
+                }
+                if (userProfileVo.getStatus().equals(3)) {
+                    userProfileExportVo.setStatus("不通过");
+                }
+                userProfileExportVo.setUserAccount(userProfileVo.getUserAccount());
+
+                //查找盖章得记录
+                UserProfileQueryBo userProfileQueryBo = new UserProfileQueryBo();
+                userProfileQueryBo.setTypeStatus(1L);
+                userProfileQueryBo.setGoodsId(userProfileVo.getGoodsId());
+                userProfileQueryBo.setUserId(userProfileVo.getUserId());
+                List<UserProfileVo> userProfile = baseMapper.selectUserProfile(userProfileQueryBo);
+                if (CollectionUtils.isNotEmpty(userProfile)) {
+                    UserProfileVo userProfileVo1 = userProfile.get(0);
+                    JsonBean jsonBean = JSON.parseObject(userProfileVo1.getKeyValue(), JsonBean.class);
+                    userProfileExportVo.setName(jsonBean.getName().getValue());
+                    userProfileExportVo.setSex(jsonBean.getSex().getValue());
+                    userProfileExportVo.setIdcard(jsonBean.getIdcard().getValue());
+                    userProfileExportVo.setTelphone(jsonBean.getTelphone().getValue());
+                    userProfileExportVo.setEducation(jsonBean.getEducation().getValue());
+                    userProfileExportVo.setSchool(jsonBean.getSchool().getValue());
+                    userProfileExportVo.setGraduation_time(DateUtil.formatDate(jsonBean.getGraduation_time().getValue()));
+                    userProfileExportVo.setWork_unit(jsonBean.getWork_unit().getValue());
+                    userProfileExportVo.setUnit_contact(jsonBean.getUnit_contact().getValue());
+                    userProfileExportVo.setUnit_tel(jsonBean.getUnit_tel().getValue());
+                    userProfileExportVo.setApply_post(jsonBean.getApply_post().getValue());
+                    userProfileExportVo.setMajor(jsonBean.getMajor().getValue());
+                    userProfileExportVo.setWorking_years(jsonBean.getWorking_years().getValue());
+                    List<String> fileList = new ArrayList<>();
+                    if (Validator.isNotEmpty(jsonBean.getRecent_photos().getValue())) {
+                        userProfileExportVo.setRecent_photos(ALIYUN_OSS_ENDPOINT + "/" + jsonBean.getRecent_photos().getValue());
+                        fileList.add(jsonBean.getRecent_photos().getValue());
+                    }
+                    if (Validator.isNotEmpty(jsonBean.getIdcard_face_photo().getValue())) {
+                        userProfileExportVo.setIdcard_face_photo(ALIYUN_OSS_ENDPOINT + "/" + jsonBean.getIdcard_face_photo().getValue());
+                        fileList.add(jsonBean.getIdcard_face_photo().getValue());
+                    }
+                    if (Validator.isNotEmpty(jsonBean.getIdcard_national_photo().getValue())) {
+                        userProfileExportVo.setIdcard_national_photo(ALIYUN_OSS_ENDPOINT + "/" + jsonBean.getIdcard_national_photo().getValue());
+                        fileList.add(jsonBean.getIdcard_national_photo().getValue());
+
+                    }
+                    if (Validator.isNotEmpty(jsonBean.getCommitment_electr_signature().getValue())) {
+                        userProfileExportVo.setCommitment_electr_signature(ALIYUN_OSS_ENDPOINT + "/" + jsonBean.getCommitment_electr_signature().getValue());
+                        fileList.add(jsonBean.getCommitment_electr_signature().getValue());
+
+                    }
+                    String dir = userProfileExportVo.getName() + "_" + userProfileExportVo.getIdcard();
+                    ossService.zipCommonDownload(fileList, outStream, dir);
+
+                }
+                userProfileExportVo.setOneTime(DateUtil.formatDateTime(new Date(userProfileVo.getOneTime() * 1000)));
+                userProfileExportVo.setLastTime(DateUtil.formatDateTime(new Date(userProfileVo.getLastTime() * 1000)));
+                userProfileExportVo.setCreateByName(userProfileVo.getCreateByName());
+                if (userProfileVo.getAuditTime() != null) {
+                    userProfileExportVo.setAuditTime(DateUtil.formatDateTime(new Date(userProfileVo.getAuditTime() * 1000)));
+                }
+                userProfileExportVos.add(userProfileExportVo);
             }
-            userProfileExportVos.add(userProfileExportVo);
+            outStream.close();
+        } catch (IOException e) {
+            System.out.println(e.getMessage() + "压缩");
         }
-        return userProfileExportVos;
+        Map<String, Object> rs = new HashMap<>();
+        rs.put("list", userProfileExportVos);
+        rs.put("zip", AjaxResult.success(filename));
+        //List<UserProfileExportGaiVo>
+        return rs;
     }
 
     /**

+ 1 - 0
zhongzheng-system/src/main/java/com/zhongzheng/modules/grade/bo/ClassGradeUserQueryBo.java

@@ -144,6 +144,7 @@ public class ClassGradeUserQueryBo extends BaseEntity {
 
 	@ApiModelProperty("班级名称")
 	private String className;
+
 	@ApiModelProperty("是否学时推送 0未推送 1推送")
 	private Integer periodPlush;
 }

+ 5 - 17
zhongzheng-system/src/main/java/com/zhongzheng/modules/grade/service/impl/ClassGradeUserServiceImpl.java

@@ -16,6 +16,7 @@ import com.zhongzheng.common.core.redis.RedisLockEntity;
 import com.zhongzheng.common.exception.CustomException;
 import com.zhongzheng.common.utils.AES;
 import com.zhongzheng.common.utils.DateUtils;
+import com.zhongzheng.common.utils.file.FileUtils;
 import com.zhongzheng.common.utils.http.HttpUtils;
 import com.zhongzheng.common.utils.polyv.PolyvUtils;
 import com.zhongzheng.modules.alioss.service.OssService;
@@ -745,8 +746,8 @@ public class ClassGradeUserServiceImpl extends ServiceImpl<ClassGradeUserMapper,
     private Map<String,Object> fillList(List<ClassPeriodStudentExportVo> list) {
         List<ClassPeriodStudentExportAllVo> newList = new ArrayList<>();
         Map<String,Object> rs = new HashMap<>();
-        String filename = encodingFilename();
-        String zipFile = getZipAbsoluteFile(filename);
+        String filename = FileUtils.encodingZipFilename("用户压缩数据");
+        String zipFile = FileUtils.getZipAbsoluteFile(filename);
         try {
             ZipOutputStream outStream = new ZipOutputStream(new FileOutputStream(zipFile));
             for (ClassPeriodStudentExportVo vo : list) {
@@ -774,22 +775,9 @@ public class ClassGradeUserServiceImpl extends ServiceImpl<ClassGradeUserMapper,
         return rs;
     }
 
-    public String encodingFilename()
-    {
-        String  filename = "用户压缩数据_"+UUID.randomUUID().toString() + ".zip";
-        return filename;
-    }
 
-    private String getZipAbsoluteFile(String filename)
-    {
-        String downloadPath = RuoYiConfig.getDownloadPath() + filename;
-        File desc = new File(downloadPath);
-        if (!desc.getParentFile().exists())
-        {
-            desc.getParentFile().mkdirs();
-        }
-        return downloadPath;
-    }
+
+
 
     private UserPeriodExportVo mergeData(Long index, String moduleName, String chapterName, String sectionName, ClassPeriodSectionVo classPeriodSectionVo, BigDecimal performance, Boolean isExam) {
         //录入学时记录

+ 2 - 1
zhongzheng-system/src/main/java/com/zhongzheng/modules/wx/service/impl/WxPayServiceImpl.java

@@ -405,9 +405,10 @@ public class WxPayServiceImpl implements IWxPayService {
                     //设置商品服务期
                     g = setServiceTime(g);
                     iOrderGoodsService.updateById(g);
+                    joinLockGrade(order.getOrderSn(), g.getGoodsId(), g.getOrderGoodsId());
                     //给用户增加商品考试次数前培次数
                     updateUserExamGoods(g, order);
-                    joinLockGrade(order.getOrderSn(), g.getGoodsId(), g.getOrderGoodsId());
+
                 }
             }
 

+ 8 - 12
zhongzheng-system/src/main/resources/mapper/modules/course/CourseMapper.xml

@@ -492,7 +492,7 @@
         <if test="userId != null and userId != ''">
         ,
         (SELECT exam_status from user_subscribe where user_id = #{userId} and goods_id = g.goods_id and subscribe_status = 1 ORDER BY subscribe_id desc limit 1)as sub_exam_status,
-        (SELECT performance from user_subscribe where user_id = #{userId}and goods_id = g.goods_id and subscribe_status = 1 ORDER BY subscribe_id desc limit 1)as sub_performance,
+        (SELECT performance from user_subscribe where user_id = #{userId} and goods_id = g.goods_id and subscribe_status = 1 ORDER BY subscribe_id desc limit 1)as sub_performance,
         (SELECT `result` from user_subscribe where user_id = #{userId} and goods_id = g.goods_id and subscribe_status = 1 ORDER BY subscribe_id desc limit 1)as sub_result,
         (SELECT subscribe_id from user_subscribe where user_id = #{userId} and goods_id = g.goods_id and subscribe_status = 1 ORDER BY subscribe_id desc limit 1)as subscribe_id,
         (SELECT apply_site_start_time from user_subscribe where user_id = #{userId} and goods_id = g.goods_id and subscribe_status = 1 ORDER BY subscribe_id desc limit 1)as sub_apply_site_start_time,
@@ -568,8 +568,13 @@
     </select>
     <select id="gradeIdSelect" parameterType="map"  resultMap="ClassGradeVoResult" >
         SELECT
-
-               IFNULL(ge.exam_num,0) as exam_num,
+         (SELECT
+        COUNT( m.id )
+        FROM
+        goods_course c  LEFT JOIN  course_menu_exam m ON m.course_id = c.course_id
+        where
+        m.type = 1
+        and c.goods_id = #{goodsId}) as exam_num,
         (SELECT COUNT(DISTINCT ubr.module_id,ubr.chapter_id,ubr.exam_id) FROM user_bank_record ubr LEFT JOIN class_grade_goods cgg on cgg.goods_id
         = ubr.goods_id where ubr.`status`=1 and ubr.report_status=1 and ubr.grade_id = cg.grade_id and ubr.user_id = cgu.user_id and ubr.current_status = 1) as record_num,
             cgu.grade_id,
@@ -591,15 +596,6 @@
             class_grade_user cgu
                 LEFT JOIN class_grade cg on cgu.grade_id = cg.grade_id
                 LEFT JOIN class_grade_goods cgg on cg.grade_id = cgg.grade_id
-        LEFT JOIN (SELECT
-        COUNT( m.id ) AS exam_num,
-        c.goods_id
-        FROM
-        course_menu_exam m
-        LEFT JOIN goods_course c ON m.course_id = c.course_id
-        where
-        m.type = 1
-        GROUP BY c.goods_id ) ge on #{goodsId} = ge.goods_id
         WHERE
             1=1
         <if test="gradeId != null and gradeId != ''">