首页 > 技术文章 > Java 后端博客系统文章系统——No2

yuandengta 2020-07-10 17:17 原文

今天这一篇,主要是关于上一张的编码实现。为什么我要单路分离出来?因为做事要分先后,明白道理,执行才能确定无误。

wordpress做的文章存储

 

在上次我们已经看过了wordpress的数据库模型(有朋友问我什么是逆向分析,拿着别人的产品逆向推导这就是逆向分析),我们可以很清楚的看到数据库关于文章存储的两张表,它们分别存储了文章的主体信息和文章的其他信息,具体的我们再看看数据库模型:

 

 


wordpress数据库模型

在上面的途中,我们很明显的看到数据库关于文章的存储主要分为两张表:

  1. wp_posts 存放文章主体信息
  2. wp_postmeta 存放文章的附加信息

 

我们先看看wp_posts的主要结构:

 

 


 

上面的数据库表,也是根据表生成的sql语句,当然注释是我加上去的。

 

可能看到这里很多朋友说我们现在只看到了表结构,而且又是你添加的注释,你这想怎么忽悠就怎么忽悠。既然这样,我们不妨一看数据库。


数据库截图片段

 

从上面的图中我们可以看到如下关键信息:


 

 

关键信息就和上面的类似了,为什么我挑选这三个:

1.博客的系统,主要的就是文章存储和多媒体资源存储

2.上面三个分别代表了文章、图片、rar压缩包

3.上面这个缩略表,刚好提取了目前我们可能会用到区分的不同信息

我们直接分析上面的数据库表中的字段。

文章

  • post_content一般有内容
  • post_status 会有多种状态
  • post_type 指向文章 post
  • post_mime_type为空

多媒体文件

  • post_content 为空
  • post_status一般是inherit
  • post_type 一般是 attachment
  • post_mime_type 一般为具体的文件类型,
  • 如:    image/png、    application/rar

 

所以根据上面的一些信息,我们可以开始实现我们文章系统下面的文章列表接口了,首先按照老规矩实现Dao层:


 

 

其实上面的接口我们可以看到和以前的差不多,毕竟数据库操作就是一些基本的增删改查。没道理的,我们必须接着实现mapper,mapper如下:

 


 

我们上面唯一需要注意的就是我们的文章查询的时候,必须指定post_type='post'post_status='publish',这样我们首页展示的文章列表就是公开的文章。

 

每次按照套路来,大家都会知道我这边Dao层完成后,就应该进行Service层的操作,那么我们看下这里我们的Service层是怎么回事。


 

 

在上面我这里在一个Service层的一个接口写这么多代码?对的,没错,我们强调的是Service层用来做数据驱动,那么我们需要在Service层完成一些基本数据的组织。所以说我们最后首页的数据如下:


 

 

由于后台数据存储的是富文本,所以我们能看到有很多网页标签。

光是这样说明也是没有多少实际意义的,我们仍然需要晒一晒具体的Controller的方法的代码,如下:


 

 

注意看我上面代码的Try-Catch处理,我这里基本目标是保证程序功能正常,不会因为我这边的异常而产生其他错误信息。

 

那我们都看到了首页上面的一些数据,那么我们现在是不是需要查看前端页面的完成呢?此处不必惊慌,前端页面的完成,我们是不会少的,而且这一期完成后的代码,我也一样会同步到github。

 

现在我们需要的是把前台页面列表加载出来并且实现局部刷新。so,我们需要先获取到前台页面,具体代码省略,我们展示核心代码:


 

当然上面的代码,必须有jquery、doT.min.js和json2.js才能运行。

推荐阅读