From f04b8922283120e2bc4a476ddc302ebd3b0894e4 Mon Sep 17 00:00:00 2001 From: Helius <wangdoubleone@gmail.com> Date: Thu, 07 Jul 2022 20:42:05 +0800 Subject: [PATCH] Merge branch 'master' of http://120.27.238.55:7000/r/farmer-cms --- src/main/java/com/xcong/farmer/cms/modules/system/service/Impl/CmsTemplateServiceImpl.java | 144 ++++++++++++++++++++++++++++++++++++++++++++++- 1 files changed, 140 insertions(+), 4 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 f1795c0..9ef6e93 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,18 +1,41 @@ package com.xcong.farmer.cms.modules.system.service.Impl; +import cn.hutool.core.io.FileUtil; +import cn.hutool.core.util.IdUtil; +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; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.xcong.farmer.cms.common.exception.GlobalException; +import com.xcong.farmer.cms.common.response.Result; +import com.xcong.farmer.cms.common.utils.FileUtils; +import com.xcong.farmer.cms.configurations.GlobalExceptionHandler; +import com.xcong.farmer.cms.configurations.properties.CmsProperties; import com.xcong.farmer.cms.core.template.TemplateConfiguration; import com.xcong.farmer.cms.modules.system.dto.TemplateListDto; import com.xcong.farmer.cms.modules.system.entity.CmsTemplateEntity; +import com.xcong.farmer.cms.modules.system.entity.UserEntity; 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; + +import java.io.File; +import java.io.FileInputStream; +import java.io.IOException; +import java.io.InputStream; +import java.nio.charset.StandardCharsets; +import java.nio.file.Files; +import java.nio.file.Paths; +import java.util.ArrayList; +import java.util.Arrays; +import java.util.List; /** * @author wzy @@ -22,12 +45,94 @@ public class CmsTemplateServiceImpl extends ServiceImpl<CmsTemplateMapper, CmsTemplateEntity> implements ICmsTemplateService { @Autowired - private TemplateConfiguration cfg; + private CmsProperties properties; + + private List<String> fileSuffix = Arrays.asList(".zip", ".html"); @Override - public void updateTemplate(MultipartFile file) { - String templatePath = cfg.templatePath; - String staticPath = cfg.staticPath; + public void updateTemplate(MultipartFile upload) { + String templatePath = properties.getTemplatePath(); + String staticPath = properties.getStaticPath(); + Long companyId = LoginUserUtil.getCompanyId(); + + String filename = upload.getOriginalFilename(); + String suffix = filename.substring(filename.lastIndexOf(".")); + + if (!fileSuffix.contains(suffix)) { + throw new GlobalException("请上传正确格式文件"); + } + + try { + String path = FileUtils.path(templatePath, filename); + File file = new File(path); + upload.transferTo(file); + + if (".zip".equals(suffix)) { + 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()) { + FileUtil.move(templateFile, new File(staticPath), true); + 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(companyId); + 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(companyId); + 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(); + } } @Override @@ -45,4 +150,35 @@ Long companyId = LoginUserUtil.getCompanyId(); this.baseMapper.delete(id, companyId); } + + @Override + public Result dropdownList() { + Long companyId = LoginUserUtil.getCompanyId(); + QueryWrapper<CmsTemplateEntity> objectQueryWrapper = new QueryWrapper<>(); + objectQueryWrapper.eq("company_id",companyId); + List<CmsTemplateEntity> cmsTemplateEntities = this.baseMapper.selectList(objectQueryWrapper); + return Result.ok(cmsTemplateEntities); + } + + @Autowired + private CmsProperties cmsProperties; + + @Override + public Result viewTemplateInfo(Long id) { + CmsTemplateEntity cmsTemplateEntity = this.baseMapper.selectById(id); + String templatePath = cmsProperties.getTemplatePath(); + String pathName = FileUtils.path(templatePath, cmsTemplateEntity.getPath()); + + byte[] bytes = new byte[0]; + try { + bytes = Files.readAllBytes(Paths.get(pathName)); + } catch (IOException e) { + e.printStackTrace(); + return Result.ok("未找到模板"); + } + + String content = new String(bytes, StandardCharsets.UTF_8); + return Result.ok(content ); + } + } -- Gitblit v1.9.1