From 4e95eb7d3040d9dc38e843b8ab8cd75a89f38984 Mon Sep 17 00:00:00 2001
From: Helius <wangdoubleone@gmail.com>
Date: Fri, 08 Jul 2022 15:31:56 +0800
Subject: [PATCH] 修改文章解析下一篇和上一篇,分页并发问题

---
 src/main/java/com/xcong/farmer/cms/core/handler/ColumnDataParserHandler.java |   15 ++++++++++-----
 1 files changed, 10 insertions(+), 5 deletions(-)

diff --git a/src/main/java/com/xcong/farmer/cms/core/handler/ColumnDataParserHandler.java b/src/main/java/com/xcong/farmer/cms/core/handler/ColumnDataParserHandler.java
index db0ebb5..50ef367 100644
--- a/src/main/java/com/xcong/farmer/cms/core/handler/ColumnDataParserHandler.java
+++ b/src/main/java/com/xcong/farmer/cms/core/handler/ColumnDataParserHandler.java
@@ -1,6 +1,7 @@
 package com.xcong.farmer.cms.core.handler;
 
 import cn.hutool.core.collection.CollUtil;
+import com.xcong.farmer.cms.configurations.properties.CmsProperties;
 import com.xcong.farmer.cms.conversion.ColumnConversion;
 import com.xcong.farmer.cms.core.node.AttrNode;
 import com.xcong.farmer.cms.core.tag.data.ColumnData;
@@ -25,7 +26,7 @@
 
     private ColumnMapper columnMapper = SpringContextHolder.getBean(ColumnMapper.class);
     private ArticleMapper articleMapper = SpringContextHolder.getBean(ArticleMapper.class);
-    private String BASE_URL = "http://192.168.0.1/";
+    private CmsProperties cmsProperties = SpringContextHolder.getBean(CmsProperties.class);
 
     @Override
     public void dataParser(AttrNode attrNode) {
@@ -36,9 +37,12 @@
 
         ColumnEntity columnEntity = columnMapper.selectByCodeAndCompanyId(param.getCode(), companyId);
 
+        if (columnEntity == null) {
+            return;
+        }
         ColumnData columnData = columnToData(columnEntity);
         if (columnEntity.getParentId() == 0L) {
-            List<ColumnEntity> child = columnMapper.selectColumnByParentId(columnEntity.getId(), companyId);
+            List<ColumnEntity> child = columnMapper.selectColumnByParentId(columnEntity.getId(), companyId, 1);
             if (CollUtil.isNotEmpty(child)) {
                 List<ColumnData> list = new ArrayList<>();
                 for (ColumnEntity entity : child) {
@@ -55,13 +59,14 @@
     public ColumnData columnToData(ColumnEntity column) {
         ColumnData columnData = ColumnConversion.INSTANCE.entityToData(column);
 
-        columnData.setUrl(BASE_URL + columnData.getCode());
+        columnData.setUrl(cmsProperties.getBaseUrl() + column.getPath());
         if (column.getType() == 2) {
             if (column.getTargetType() == 1) {
                 ArticleEntity article = this.articleMapper.selectArticleById(Long.parseLong(column.getTargetUrl()));
-                columnData.setUrl(BASE_URL + article.getColumnCode() + "/" + article.getId() + ".html");
+                columnData.setUrl(cmsProperties.getBaseUrl() + article.getPath() + "/" + article.getId() + ".html");
             } else if (column.getTargetType() == 2) {
-                columnData.setUrl(BASE_URL + column.getTargetUrl());
+                ColumnEntity columnEntity = this.columnMapper.selectByCodeAndCompanyId(column.getTargetUrl(), column.getCompanyId());
+                columnData.setUrl(cmsProperties.getBaseUrl() + columnEntity.getPath());
             } else {
                 columnData.setUrl(column.getTargetUrl());
             }

--
Gitblit v1.9.1