写点什么

Java 后端博客系统文章系统——No2

用户头像
猿灯塔
关注
发布于: 2020 年 07 月 10 日
Java 后端博客系统文章系统——No2



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



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才能运行。



用户头像

猿灯塔

关注

猿灯塔-做程序员的引导者! 2020.04.02 加入

我们立志作为IT行业知识大海的一座座灯塔,为想在这个行业中奋斗的你们指明正确的方向,引领大家一起前进。

评论

发布
暂无评论
Java 后端博客系统文章系统——No2