From 312dc55b139d16a73e58cd6899865e11e86c6fdc Mon Sep 17 00:00:00 2001 From: Helius <wangdoubleone@gmail.com> Date: Mon, 04 Jul 2022 19:46:15 +0800 Subject: [PATCH] fix --- src/main/java/com/xcong/farmer/cms/modules/system/service/Impl/CmsTemplateServiceImpl.java | 75 ++++++++++++++++++++++++++++++++++--- 1 files changed, 69 insertions(+), 6 deletions(-) diff --git a/src/main/java/com/xcong/farmer/cms/modules/system/service/Impl/CmsTemplateServiceImpl.java b/src/main/java/com/xcong/farmer/cms/modules/system/service/Impl/CmsTemplateServiceImpl.java index f1e072f..807d28e 100644 --- a/src/main/java/com/xcong/farmer/cms/modules/system/service/Impl/CmsTemplateServiceImpl.java +++ b/src/main/java/com/xcong/farmer/cms/modules/system/service/Impl/CmsTemplateServiceImpl.java @@ -1,5 +1,8 @@ package com.xcong.farmer.cms.modules.system.service.Impl; +import cn.hutool.core.io.FileUtil; +import cn.hutool.core.util.StrUtil; +import cn.hutool.core.util.ZipUtil; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; @@ -13,6 +16,8 @@ import com.xcong.farmer.cms.modules.system.mapper.CmsTemplateMapper; import com.xcong.farmer.cms.modules.system.service.ICmsTemplateService; import com.xcong.farmer.cms.modules.system.util.LoginUserUtil; +import org.jsoup.Jsoup; +import org.jsoup.nodes.Document; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.web.multipart.MultipartFile; @@ -48,17 +53,75 @@ } try { + String path = FileUtils.path(templatePath, filename); + File file = new File(path); + upload.transferTo(file); + if (".zip".equals(suffix)) { - String path = FileUtils.path(templatePath, filename); - System.out.println(path); - File file = new File(path); - upload.transferTo(file); - FileUtils.zipUpload(file, templatePath, staticPath); + ZipUtil.unzip(file, new File(templatePath)); + FileUtil.del(file); + + File template = new File(templatePath); + File[] files = template.listFiles(); + if (files == null) { + return; + } + + for (File templateFile : files) { + if (!templateFile.isFile()) { + continue; + } + + if (!"html".equals(FileUtil.extName(templateFile))) { + continue; + } + + String name = templateFile.getName(); + if (!name.endsWith(".list.html") && !name.endsWith(".article.html") && !name.endsWith(".index.html")) { + continue; + } + + Document parse = Jsoup.parse(templateFile, null); + String attr = parse.head().attr("name"); + CmsTemplateEntity cmsTemplate = new CmsTemplateEntity(); + cmsTemplate.setCompanyId(10L); + if (name.endsWith(".list.html")) { + cmsTemplate.setType(2); + } else if (name.endsWith(".article.html")) { + cmsTemplate.setType(3); + } else { + cmsTemplate.setType(1); + } + cmsTemplate.setName(StrUtil.isNotBlank(attr) ? attr : templateFile.getName()); + cmsTemplate.setPath(templateFile.getName()); + + this.baseMapper.insert(cmsTemplate); + } + + } + + if (".html".equals(suffix)) { + FileUtil.touch(file); + + Document parse = Jsoup.parse(file, null); + String attr = parse.head().attr("name"); + CmsTemplateEntity cmsTemplate = new CmsTemplateEntity(); + cmsTemplate.setCompanyId(LoginUserUtil.getCompanyId()); + if (file.getName().endsWith(".list.html")) { + cmsTemplate.setType(2); + } else if (file.getName().endsWith(".article.html")) { + cmsTemplate.setType(3); + } else { + cmsTemplate.setType(1); + } + cmsTemplate.setName(StrUtil.isNotBlank(attr) ? attr : file.getName()); + cmsTemplate.setPath(file.getName()); + + this.baseMapper.insert(cmsTemplate); } } catch (IOException e) { e.printStackTrace(); } - System.out.println(suffix); } @Override -- Gitblit v1.9.1