From 4542d50cd5a6f25b2b9c7410be45992af87a8f5e Mon Sep 17 00:00:00 2001 From: Helius <wangdoubleone@gmail.com> Date: Sat, 09 Jul 2022 17:35:23 +0800 Subject: [PATCH] 修改模板上传逻辑 --- src/main/java/com/xcong/farmer/cms/modules/system/service/Impl/CmsTemplateServiceImpl.java | 73 ++++++++++++++---------- src/main/java/com/xcong/farmer/cms/core/node/AttrNode.java | 25 -------- src/test/java/com/xcong/farmer/cms/TemplateTest.java | 52 +++++++++++++++++ 3 files changed, 94 insertions(+), 56 deletions(-) diff --git a/src/main/java/com/xcong/farmer/cms/core/node/AttrNode.java b/src/main/java/com/xcong/farmer/cms/core/node/AttrNode.java index f29380d..436b082 100644 --- a/src/main/java/com/xcong/farmer/cms/core/node/AttrNode.java +++ b/src/main/java/com/xcong/farmer/cms/core/node/AttrNode.java @@ -80,32 +80,7 @@ return false; } - public void staticPath() { - // 设置img的链接访问 - if ("img".equals(this.element.tagName())) { - String src = this.element.attr("src"); - if (StrUtil.isNotBlank(STATIC_URL)) { - this.element.attr("src", STATIC_URL + src); - } - } - - if ("link".equals(this.element.tagName())) { - String src = this.element.attr("href"); - if (StrUtil.isNotBlank(STATIC_URL)) { - this.element.attr("href", STATIC_URL + src); - } - } - - if ("script".equals(this.element.tagName())) { - String src = this.element.attr("src"); - if (StrUtil.isNotBlank(STATIC_URL)) { - this.element.attr("src", STATIC_URL + src); - } - } - } - public void parser() { - staticPath(); // 判断是否为最小节点,如果是且没有特殊标签,则跳过清空 if (!isNeedEmpty()) { return; 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 5c20554..a2b9230 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 @@ -20,6 +20,8 @@ import com.xcong.farmer.cms.modules.system.util.LoginUserUtil; import org.jsoup.Jsoup; import org.jsoup.nodes.Document; +import org.jsoup.nodes.Element; +import org.jsoup.select.Elements; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; @@ -88,46 +90,55 @@ 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); + insertTemplate(templateFile, companyId); } - } 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); + insertTemplate(file, companyId); } } catch (IOException e) { e.printStackTrace(); + throw new GlobalException("模板上传失败"); + } + } + + private void insertTemplate(File file, Long companyId) throws IOException { + Document parse = Jsoup.parse(file, null); + String attr = parse.head().attr("name"); + + staticPathParser(parse, "img", "src"); + staticPathParser(parse, "href", "link"); + staticPathParser(parse, "script", "src"); + + 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); + } + + private void staticPathParser(Document document, String tagName, String attrKey) { + Elements elements = document.getElementsByTag(tagName); + if (elements.isEmpty()) { + return; + } + + for (Element element : elements) { + String attr = element.attr(attrKey); + if (StrUtil.isNotBlank(attr) && !attr.contains("http://") && !attr.contains("https://")) { + element.attr(attrKey, cmsProperties.getBaseUrl() + attr); + } } } diff --git a/src/test/java/com/xcong/farmer/cms/TemplateTest.java b/src/test/java/com/xcong/farmer/cms/TemplateTest.java new file mode 100644 index 0000000..f072ef2 --- /dev/null +++ b/src/test/java/com/xcong/farmer/cms/TemplateTest.java @@ -0,0 +1,52 @@ +package com.xcong.farmer.cms; + +import cn.hutool.core.io.FileUtil; +import cn.hutool.core.util.StrUtil; +import org.jsoup.Jsoup; +import org.jsoup.nodes.Document; +import org.jsoup.nodes.Element; +import org.jsoup.select.Elements; +import org.junit.jupiter.api.Test; +import org.springframework.boot.test.context.SpringBootTest; + +import java.io.File; +import java.io.FileOutputStream; +import java.io.IOException; + +/** + * @author wzy + * @date 2022-07-09 + **/ +@SpringBootTest +public class TemplateTest { + + String baseUrl = "http://120.27.238.55:8000/cms/static/"; + + @Test + public void staticFileTest() throws IOException { + File file = new File("/Users/helius/Desktop/template-online/index-test.html"); + Document parse = Jsoup.parse(file, "utf-8"); + + staticPathParser(parse, "img", "src"); + staticPathParser(parse, "href", "link"); + staticPathParser(parse, "script", "src"); + + FileOutputStream outputStream = new FileOutputStream(file); + outputStream.write(parse.html().getBytes()); + outputStream.close(); + } + + public void staticPathParser(Document document, String tagName, String attrKey) { + Elements elements = document.getElementsByTag(tagName); + if (elements.isEmpty()) { + return; + } + + for (Element element : elements) { + String attr = element.attr(attrKey); + if (StrUtil.isNotBlank(attr) && !attr.contains("http://") && !attr.contains("https://")) { + element.attr(attrKey, baseUrl + attr); + } + } + } +} -- Gitblit v1.9.1