工具

IDE为idea16

JDK环境为1.8

gradle构建,版本:2.14.1

Mysql版本为5.5.27

Tomcat版本为7.0.52

流程图绘制(xmind)

建模分析软件PowerDesigner16.5

数据库工具MySQLWorkBench,版本:6.3.7build

本期目标

mybatis一些简单的进阶使用

日志功能的记录

文章发布

草稿保存

上期我们通过对数据库的分析,仔仔细细的探索了一遍WordPress程序运行时候文章提交和草稿提交的区别和共同点,简略的概括下如下:

文章和草稿区别是postType不同

文章和草稿都有日志记录

日志的postStatus都是closed

日志的postParent始终是指向其文章的id

···

更为详细的文章,建议去我的上一篇文章查看。

既然我们已经大概明白了怎么去实现,那么现在我们需要的就是进行实验。

首先老规矩,先从我们的dao层实现开始,我们争取把各个功能模块解耦,那么我们就不能过于在dao层限制,所以我们需要在dao层实现数据(文章、草稿、历史记录)插入。所以我们先生成dao接口如下:

上面的语句中我们可以看到在mapper的insert语句块中我们插入了selectKey语句块,主要是用来返回我们插入的条目的自增id。为什么这里我们非要获取到插入的id呢?主要是文章生成后的日志记录都是需要文章id才能生成对应的日志记录。

同时在inset语句块中,我们使用了choose+when语句块生成了动态sql,这样就能动态的选择程序执行。

同时在上面的代码中我们可以看到上面的when和下面的when语句块中关于bean的属性获取使用方式不一样!

重点:扩展类型,要使用父类的属性时,必须是对象名.属性名的形式,对象名从dao的接口设置。(否则直接使用属性的时候,会异常提示空指针,且提示对象的属性中没有该属性)

小技巧:

1.在mapper中使用属性时,最好是对象名.属性名的方式,同时在dao层中设置对象的名称(在我们上面dao层的add接口中有说明)

2.mybatis的动态sql可以减少很多额外的方法和mapper中的sql编写,所以必须掌握动态sql

3.当属性较多的时候,我们一定不能忘记单元测试,单元测试可以简单直观的了解到哪里出错,减少在后续开发中错误检查的时间。

上面我们也是提到过单元测试,那么我们现在看看这个dao的单元测试应该如何完成呢?

首先给大家看看我们文章的bean:

说实话,一看到这里的时候,我也很惆怅。灵机一动,感觉可以祭出这个系列教程我们自己手写的第一个设计模式了!开启我们的javaBean的建造者模式。

那么我们ben生成好了后,我们就需要开始写我们的单元测试,如下:

大家可以看到上面我们的PostCustom还是从我们自己手动封装的PostInitUtils中获取的,同时我们的PostCustom还是我们的PostBean的子类。所以这里就用到了传说中的pojo包装类型相关的一些知识

(我们这里并没有包装,不过已经用到了扩展类),让我们接着看看PostInitUtils的代码:

这里我们可以看到我们对外开放的核心也就文章核心信息相关的一些东西了,那么这样我们就能很好的控制数据。

现在我们可以看下数据库,最新多出来的数据和文章首页插入的数据如下:

我们今天的主干内容到此基本完成,剩下的从dao到前台界面适配等等基本上骚年们自己都可以完成至此不在赘述。

java网络文章博客抓取系统_java 后端博客系统文章系统——No6相关推荐

  1. java网络文章博客抓取系统_java 后端博客系统文章系统——No3

    工具 IDE为idea16* JDK环境为1.8 gradle构建,版本:2.14.1 Mysql版本为5.5.27 Tomcat版本为7.0.52 流程图绘制(xmind) 建模分析软件PowerD ...

  2. JAVA+网络数据包的抓取与分析实验

    一.实验目的 熟悉TC P/IP数据包的结构. 掌握Wireshark的使用方法. 能够利用JNet Pcap编程实现数据包的抓取与分析. 二.实验准备 1.通过抓包,可以进行网络故障分析.流量监控. ...

  3. 如何控制Yahoo! Slurp蜘蛛的抓取频度_国外博客资源站_百度空间

    如何控制Yahoo! Slurp蜘蛛的抓取频度_国外博客资源站_百度空间 如何控制Yahoo! Slurp蜘蛛的抓取频度 2009年08月13日 星期四 5:56 上周末豆瓣的阿北给我电话:最近你们雅 ...

  4. 网络漫画爬虫:抓取漫画章节和图片

    目录 摘要 1. 介绍 2. 环境准备 安装Python和相应库 3. 爬虫基础知识 HTTP请求和响应 解析网页内容 Robots.txt文件 4. 抓取漫画章节 选择目标网站 发送HTTP请求 解 ...

  5. 基于Java的阿里妈妈数据抓取技术

    基于Java的阿里妈妈数据抓取技术 前言: 对于需要登录的网站爬虫最大的困难就是需要登录,然后才能获取到数据,如微博,阿里妈妈,webqq等.之前也有看过使用浏览器登录到网站后直接从浏览器中获取coo ...

  6. php 采集qq空间,php使用curl抓取qq空间的访客信息示例_php技巧

    这篇文章主要介绍了php使用curl抓取qq空间的访客信息示例,需要的朋友可以参考下 config.php<?php define('APP_DIR', dirname(__FILE__)); ...

  7. java socket抓取资源_Java 通过 Socket 的形式抓取网页内容

    package com.hmw.net; import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.IO ...

  8. UC头条(大鱼)文章评论内容抓取

    下面以某一篇文章为例,分析UC头条(大鱼)文章评论内容抓取: 首先我们点击进入上面的这一篇文章,然后拉到评论内容区,通过抓包分析发现其评论接口为: https://m.uczzd.cn/iflow/a ...

  9. 22.网络爬虫—APP数据抓取详讲

    网络爬虫-APP数据抓取详讲 Fiddler 工作原理 安装完成Fiddler后的配置 前提条件 工具配置 手机数据抓取 Fiddler手机端配置 手机端操作 实战演示 后记 前言:

最新文章

  1. 安装NodeJS环境报错
  2. getDay()显示的是本周的第几天
  3. python软件包自带的集成开发环境-Python: 内置的集成开发环境-IDLE
  4. ssh登录慢,等待时间长的问题
  5. 没有运行 spring_Spring事务的传播行为案例分析
  6. [html]history禁用浏览器的后退功能(包括其他操作后退的按钮,操作等)
  7. python表单处理_python flask 表单处理Flask-WTF
  8. 工作流实战_07_flowable 流程定义查看流程图和xml
  9. 力改变物体形状举例_人教版八年级物理下册第七章《力》知识点大全
  10. Httputils请求网络数据
  11. 华为云发布“华为鲲鹏”培训认证体系,助力开发者“化鲲为鹏”
  12. 苹果这个酷炫的项目要流产了?市场未爆发或成主因
  13. java 重启线程_java-如何重新启动线程
  14. u盘无媒体容量0无卷还能修吗_都2020年了,买新U盘没Type-C接口就过时了
  15. SentinelResource注解配置中_客户自定义限流处理_削峰填谷_流量控制_速率控制_服务熔断_服务降级---微服务升级_SpringCloud Alibaba工作笔记0046
  16. 基于stm32单片机外文文献_基于STM32的智能家居系统设计毕业论文+任务书+开题报告+文献综述+外文翻译及原文+程序+原理图+参考资料+答辩PPT+仿真设计...
  17. 微信小程序之海报生成
  18. 2019年最新手游脚本开发教程
  19. The types of the interface org.apache.flink.util.OutputTag could not be inferred.
  20. 数据挖掘——关联规则挖掘

热门文章

  1. 国产半导体划片机设备迎发展良机
  2. java语言程序设计第三次形考_西安交通大学19年3月课程考试《有机化学》作业考核(标准答案)...
  3. 【UCML】统计行重写值
  4. python回归方程系数计算_python中的回归系数计算
  5. [wargame.kr 韩国 CTF] Writeup
  6. 周末又没有了......
  7. Kubernetes与OpenShift区别
  8. 关于我使用vant组件的踩坑日记
  9. 【生活】忙忙碌碌的城市中要给予生活以呼吸
  10. jquery选择器动态拼接