Compare commits

...

2 Commits

Author SHA1 Message Date
Revers 49a0d4cb4e add advertisement cache
10 months ago
Revers 56821c988e fix article and add cache
10 months ago

@ -28,6 +28,10 @@ public class Constants {
public static final String J2CACHE_REGION_SEARCH_AUTO_COMPLETE = "search_auto_complete";
public static final String J2CACHE_REGION_JOURNAL_HOT_COMMENTS = "journal_hot_comments";
public static final String J2CACHE_REGION_ARTICLE = "article";
public static final String J2CACHE_REGION_ARTICLE_PAGE = "article_page";
public static final String J2CACHE_REGION_ADVERTISEMENT = "advertisement";
public static final String J2CACHE_REGION_ADVERTISEMENT_PAGE = "advertisement_page";
public static final String RABBIT_MESSAGE_CLEAN_JOURANL_QUERY_PAGE = "clean_journal_query_page";

@ -1,19 +1,20 @@
package com.luoo.music.dto.response.cms;
import com.luoo.music.pojo.Advertisement;
import com.luoo.music.pojo.Article;
import com.luoo.music.util.Constants;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import org.apache.commons.lang.StringUtils;
import java.io.Serializable;
/**
* @author Revers.
* @date 2024/02/23 21:33
**/
@Data
public class AdvertisementRespDTO {
public class AdvertisementRespDTO implements Serializable {
private static final long serialVersionUID = 1L;
@ApiModelProperty(value = "ID")
private String id;

@ -45,8 +45,8 @@ public class ArticleRespDTO implements Serializable {
@ApiModelProperty(value = "是否允许评论 否0 是1")
private String allowCommit;
@ApiModelProperty(value = "是否自动推送 否:0 是1")
private String autoPush;
@ApiModelProperty(value = "是否自动推送 否:false 是true")
private Boolean autoPush;
@ApiModelProperty(value = "总评论数,大于99显示99+")
private Long totalCommentReply;
@ -76,7 +76,7 @@ public class ArticleRespDTO implements Serializable {
response.setIsScheduled(article.getIsScheduled());
response.setPubTime(article.getPubTime().format(DateTimeFormatter.ISO_DATE_TIME));
response.setAllowCommit(article.getAllowCommit());
response.setAutoPush(article.getAutoPush());
response.setAutoPush("1".equals(article.getAutoPush())?true:false);
response.setSongId(article.getSongId());
return response;

@ -2,6 +2,7 @@ package com.luoo.music.service;
import api.PageResult;
import api.Result;
import com.alibaba.fastjson.JSON;
import com.luoo.music.client.UserClient;
import com.luoo.music.dao.AdvertisementDao;
import com.luoo.music.dto.request.cms.AdvertisementReqModel;
@ -9,6 +10,7 @@ import com.luoo.music.dto.response.cms.AdvertisementRespDTO;
import com.luoo.music.pojo.Advertisement;
import com.luoo.music.pojo.UserInfo;
import com.luoo.music.util.Constants;
import net.oschina.j2cache.CacheChannel;
import org.apache.commons.lang.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.domain.Example;
@ -28,7 +30,6 @@ import java.time.LocalDateTime;
import java.util.ArrayList;
import java.util.List;
import java.util.Objects;
import java.util.Optional;
/**
* @author Revers.
@ -46,6 +47,9 @@ public class CMSAdvertisementService {
@Autowired
private UserClient userClient;
@Autowired
private CacheChannel cacheChannel;
public Result add(AdvertisementReqModel paramAdd) {
String image = null;
if (StringUtils.isNotBlank(paramAdd.getImage())) {
@ -90,6 +94,7 @@ public class CMSAdvertisementService {
if(!adDao.exists(example)) {
adDao.save(ad);
cleanAdCache(ad.getId());
}
return Result.success();
@ -109,22 +114,23 @@ public class CMSAdvertisementService {
}
public Result deleteById(String id){
Advertisement ad = adDao.findById(id).get();
Advertisement ad = JSON.parseObject(getAdFromCache(id), Advertisement.class);
if (!Objects.isNull(ad)) {
ad.setIsDeleted("1");
adDao.save(ad);
cleanAdCache(ad.getId());
return Result.success();
}
return Result.failed("广告不存在");
}
public Result update(String id,AdvertisementReqModel param){
Optional<Advertisement> optional = adDao.findById(id);
if (!optional.isPresent()) {
Advertisement ad = JSON.parseObject(getAdFromCache(id), Advertisement.class);
if (ad == null) {
return Result.failed("找不到广告: " + id);
}
Advertisement ad = optional.get();
//如果图片路径存在 temp/ 则为新图片
if (StringUtils.isNotBlank(param.getImage()) && param.getImage().contains(Constants.TEMP_KEY_PREFIX)) {
@ -151,16 +157,16 @@ public class CMSAdvertisementService {
ad.setSummary(contentToSummary(param.getContent()));
adDao.save(ad);
cleanAdCache(ad.getId());
return Result.success();
}
public Result<AdvertisementRespDTO> findOne(String id) {
Optional<Advertisement> optional=adDao.findById(id);
if(!optional.isPresent()) {
Advertisement ad = JSON.parseObject(getAdFromCache(id), Advertisement.class);
if(ad == null) {
return Result.failed("无法找到广告: " + id);
}
Advertisement ad = optional.get();
if("1".equals(ad.getIsDeleted())){
return Result.success(null);
@ -175,20 +181,8 @@ public class CMSAdvertisementService {
}
public Result<PageResult<AdvertisementRespDTO>> search(int page, int size,String location) {
List<AdvertisementRespDTO> result = new ArrayList<>();
PageRequest pageRequest = PageRequest.of(page - 1, size);
Specification<Advertisement> AdSpecification = buildSearchSpecification(location);
Page<Advertisement> AdPage = adDao.findAll(AdSpecification,pageRequest);
long totalElements = AdPage.getTotalElements();
List<Advertisement> content = AdPage.getContent();
if (!CollectionUtils.isEmpty(content)) {
for (Advertisement item : content) {
AdvertisementRespDTO response = AdvertisementRespDTO.convertPojo(item);
result.add(response);
}
}
return Result.success(new PageResult<>(totalElements, result));
List<AdvertisementRespDTO> pageAdFromCache = getPageAdFromCache(page, size, location);
return Result.success(new PageResult<>(Long.valueOf(pageAdFromCache.size()), pageAdFromCache));
}
private Specification<Advertisement> buildSearchSpecification(String location) {
return (Root<Advertisement> root, CriteriaQuery<?> query, CriteriaBuilder builder) -> {
@ -228,13 +222,53 @@ public class CMSAdvertisementService {
}
public Result visitAdd(String id){
Advertisement advertisement = adDao.findById(id).get();
if (!Objects.isNull(advertisement)) {
advertisement.setVisits(advertisement.getVisits()+1);
adDao.save(advertisement);
Advertisement ad = JSON.parseObject(getAdFromCache(id), Advertisement.class);
if (!Objects.isNull(ad)) {
ad.setVisits(ad.getVisits()+1);
adDao.save(ad);
cleanAdCache(ad.getId());
return Result.success();
}
return Result.failed("文章不存在");
return Result.failed("广告不存在");
}
private List<AdvertisementRespDTO> getPageAdFromCache(int page , int size,String location){
return (List<AdvertisementRespDTO>) cacheChannel.get(constants.Constants.J2CACHE_REGION_ADVERTISEMENT_PAGE, page+","+size, key -> getPageAd(page,size,location), false).getValue();
}
private List<AdvertisementRespDTO> getPageAd(int page , int size,String location){
List<AdvertisementRespDTO> result = new ArrayList<>();
PageRequest pageRequest = PageRequest.of(page - 1, size);
Specification<Advertisement> AdSpecification = buildSearchSpecification(location);
Page<Advertisement> AdPage = adDao.findAll(AdSpecification,pageRequest);
List<Advertisement> content = AdPage.getContent();
if (!CollectionUtils.isEmpty(content)) {
for (Advertisement item : content) {
AdvertisementRespDTO response = AdvertisementRespDTO.convertPojo(item);
result.add(response);
}
}
return result;
}
private String getAdFromCache(String id){
return (String) cacheChannel.get(constants.Constants.J2CACHE_REGION_ADVERTISEMENT, id, key -> getAdById(id), false).getValue();
}
private String getAdById(String id){
return JSON.toJSONString(adDao.findById(id).get());
}
private void cleanAdCache(String id){
cacheChannel.evict(constants.Constants.J2CACHE_REGION_ADVERTISEMENT,id);
cacheChannel.clear(constants.Constants.J2CACHE_REGION_ADVERTISEMENT_PAGE);
}
}

@ -2,6 +2,7 @@ package com.luoo.music.service;
import api.PageResult;
import api.Result;
import com.alibaba.fastjson.JSON;
import com.luoo.music.client.UserClient;
import com.luoo.music.dao.*;
import com.luoo.music.dto.request.cms.ArticleAddModel;
@ -11,6 +12,7 @@ import com.luoo.music.pojo.Article;
import com.luoo.music.pojo.Comment;
import com.luoo.music.pojo.UserInfo;
import com.luoo.music.util.Constants;
import net.oschina.j2cache.CacheChannel;
import org.apache.commons.lang.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.domain.Example;
@ -55,6 +57,9 @@ public class CMSArticleService {
@Autowired
private CommentDao commentDao;
@Autowired
private CacheChannel cacheChannel;
public Result add(ArticleAddModel paramAdd) {
String image = null;
@ -79,6 +84,7 @@ public class CMSArticleService {
if(!articleDao.exists(example)) {
articleDao.save(article);
cleanArticleCache(article.getId());
}
return Result.success();
@ -151,31 +157,32 @@ public class CMSArticleService {
}
public Result deleteById(String id){
Article article = articleDao.findById(id).get();
Article article = JSON.parseObject(getArticleFromCache(id), Article.class);
if (!Objects.isNull(article)) {
article.setIsDeleted("1");
articleDao.save(article);
cleanArticleCache(article.getId());
return Result.success();
}
return Result.failed("文章不存在");
}
public Result visitAdd(String id){
Article article = articleDao.findById(id).get();
Article article = JSON.parseObject(getArticleFromCache(id), Article.class);
if (!Objects.isNull(article)) {
article.setVisits(article.getVisits()+1);
articleDao.save(article);
cleanArticleCache(id);
return Result.success();
}
return Result.failed("文章不存在");
}
public Result update(String id,ArticleAddModel param){
Optional<Article> optional = articleDao.findById(id);
if (!optional.isPresent()) {
return Result.failed("找不到期刊: " + id);
Article article = JSON.parseObject(getArticleFromCache(id), Article.class);
if (article == null) {
return Result.failed("找不到文章: " + id);
}
Article article = optional.get();
//如果图片路径存在 temp/ 则为新图片
if (StringUtils.isNotBlank(param.getImage()) && param.getImage().contains(Constants.TEMP_KEY_PREFIX)) {
@ -207,70 +214,55 @@ public class CMSArticleService {
article.setPubTime(param.getPubTime());
articleDao.save(article);
cleanArticleCache(article.getId());
//TODO: 发布方式
return Result.success();
}
public Result<ArticleRespDTO> findOne(String id) {
Optional<Article> optional=articleDao.findById(id);
if(!optional.isPresent()) {
return Result.failed("无法找到文章: " + id);
}
Article article = optional.get();
Article article = JSON.parseObject(getArticleFromCache(id), Article.class);
if("1".equals(article.getIsDeleted())){
return Result.success(null);
}else {
ArticleRespDTO response = ArticleRespDTO.convertPojo(article);
}
ArticleRespDTO response = ArticleRespDTO.convertPojo(article);
/**
*
*/
/**
*
*/
String totalString = "0";
String totalString = "0";
totalString = "0";
Criteria criteria = Criteria.where("journalId").is(article.getId());
Aggregation agg = Aggregation.newAggregation(Aggregation.match(criteria), // 匹配条件
Aggregation.group().sum("commentCount").as("totalComment"));
AggregationResults<TotalCommentVo> results = mongoTemplate.aggregate(agg, "comment", TotalCommentVo.class);
TotalCommentVo totalCommentVo = results.getUniqueMappedResult();
totalString = "0";
Criteria criteria = Criteria.where("journalId").is(article.getId());
Aggregation agg = Aggregation.newAggregation(Aggregation.match(criteria), // 匹配条件
Aggregation.group().sum("commentCount").as("totalComment"));
AggregationResults<TotalCommentVo> results = mongoTemplate.aggregate(agg, "comment", TotalCommentVo.class);
TotalCommentVo totalCommentVo = results.getUniqueMappedResult();
// commentDTO.setTotalCommentReply("0");
List<Comment> list = commentDao.findByJournalId(article.getId());
int total = 0;
if (null != list && list.size() > 0) {
total = list.size();
}
if (null != totalCommentVo) {
total = total + totalCommentVo.getTotalComment();
totalString = total + "";
if (total > 99) {
totalString = "99+";
}
List<Comment> list = commentDao.findByJournalId(article.getId());
int total = 0;
if (null != list && list.size() > 0) {
total = list.size();
}
if (null != totalCommentVo) {
total = total + totalCommentVo.getTotalComment();
totalString = total + "";
if (total > 99) {
totalString = "99+";
}
response.setTotalCommentReply(Long.valueOf(total));
}
response.setTotalCommentReply(Long.valueOf(total));
return Result.success(response);
}
return Result.success(response);
}
public Result<PageResult<ArticleRespDTO>> search(int page, int size) {
List<ArticleRespDTO> result = new ArrayList<>();
PageRequest pageRequest = PageRequest.of(page - 1, size);
Specification<Article> articleSpecification = buildSearchSpecification();
Page<Article> ArticlePage = articleDao.findAll(articleSpecification,pageRequest);
long totalElements = ArticlePage.getTotalElements();
List<Article> content = ArticlePage.getContent();
if (!CollectionUtils.isEmpty(content)) {
for (Article item : content) {
ArticleRespDTO response = ArticleRespDTO.convertPojo(item);
result.add(response);
}
}
return Result.success(new PageResult<>(totalElements, result));
List<ArticleRespDTO> pageArticleFromCache = getPageArticleFromCache(page, size);
return Result.success(new PageResult<>(Long.valueOf(pageArticleFromCache.size()), pageArticleFromCache));
}
private Specification<Article> buildSearchSpecification() {
return (Root<Article> root, CriteriaQuery<?> query, CriteriaBuilder builder) -> {
@ -294,4 +286,40 @@ public class CMSArticleService {
String cleanedString = cleanedStringBuilder.toString();
return cleanedString.length() >=150 ? cleanedString.substring(0,150):cleanedString;
}
private List<ArticleRespDTO> getPageArticleFromCache(int page , int size){
return (List<ArticleRespDTO>) cacheChannel.get(constants.Constants.J2CACHE_REGION_ARTICLE_PAGE, page+","+size, key -> getPageArticle(page,size), false).getValue();
}
private List<ArticleRespDTO> getPageArticle(int page , int size){
List<ArticleRespDTO> result = new ArrayList<>();
PageRequest pageRequest = PageRequest.of(page - 1, size);
Specification<Article> articleSpecification = buildSearchSpecification();
Page<Article> ArticlePage = articleDao.findAll(articleSpecification,pageRequest);
List<Article> content = ArticlePage.getContent();
if (!CollectionUtils.isEmpty(content)) {
for (Article item : content) {
ArticleRespDTO response = ArticleRespDTO.convertPojo(item);
result.add(response);
}
}
return result;
}
private String getArticleFromCache(String id){
return (String) cacheChannel.get(constants.Constants.J2CACHE_REGION_ARTICLE, id, key -> getArticleById(id), false).getValue();
}
private String getArticleById(String id){
return JSON.toJSONString(articleDao.findById(id).get());
}
private void cleanArticleCache(String id){
cacheChannel.evict(constants.Constants.J2CACHE_REGION_ARTICLE,id);
cacheChannel.clear(constants.Constants.J2CACHE_REGION_ARTICLE_PAGE);
}
}

@ -43,6 +43,10 @@ caffeine:
journal_song_list: 2000, 365d
search_auto_complete: 200000, 365d
user_info: 20000, 365d
article: 2000, 365d
article_page: 2000, 365d
advertisement: 2000, 365d
advertisement_page: 2000, 365d
#caffeine:
# properties: caffeine.properties
---

Loading…
Cancel
Save