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

  • 相关阅读:
    T-SQL常用的函数
    webservice和wcf和web.api简单介绍
    c#索引器
    在eclipse中使用maven构建spring cloud微服务
    maven项目报错maven-resources-plugin:2.7 or one of its dependencies could not be resolved
    使用maven创建工程报错Could not resolve archetype org.apache.maven.archetype
    eclipse配置maven
    最新省市区json数据
    ORA-01461: can bind a LONG value only for insert into a LONG column
    js验证强密码 大小写字母数字字符四选三 且大于8位
  • 原文地址:https://www.cnblogs.com/yuandengta/p/13280262.html
Copyright © 2020-2023  润新知