#框架搭建
用springboot初始化工具,选模块(web,thymeleaf,jpa,mysql,Devtools,Aspects(日志处理)),等待,第一次时间较长,能干一下午也是正常的。
先逛逛pom文件,这里可以导依赖,管理版本。
配置文件,有两种(property,yml),这里用yml。
以下目录结构,第一个是总配置,里面可以定义thymeleaf,以及在什么环境下选下面(application-dev,application-pro)哪种的配置,是生产环境还是开发环境,这对于日志的打印级别是不同的。对于application-dev,application-pro这两个文件,自然就是开发时,生产时的配置。最后一个文件时,自定义一些打印日志的规范,可打破默认的10m大小的限制。
application:
application—pro:
application—dev:
#异常处理
定义404,500,error这些错误页面,springboot会根据错误状态码去跳转到对应的文件。
新建控制器,来调试这些错误页面,如果跳转不到500页面,把property文件thymeleaf那两行去掉即可。
显然,控制器内的代码有问题,分母不能为零,这会报一个500错误,因为这是服务端的错误;
如果,在浏览器里瞎打一个网址,显然会找不到,所以自然就会报一个404.
自定义错误页面,自然要自建拦截器。
这样一个处理器,通过ModelAndView,把路由和异常信息,以及自定义的错误页面路由都设置好。
这是日志信息的格式。
那在错误页面里怎么打印错误信息呢?当然,用thymeleaf模板来处理前端最合适不过了。
下面,就能使错误信息以纯文本的格式来打印。
为了更好的实现,我们自己要定义异常,以及抛出异常。
自定义异常,并设置状态为找不到资源(HTTPStatus.NOT_FOUND),即会报404错误。
再看一下控制器,抛出异常:
当然,之前我们做了异常拦截器,这个东西会把所有的异常都跳到我们自定义的error页面,so,我们还要做点逻辑的判断,判断下状态码,不为空的话,就抛出异常。
#使用AOP作日志处理
以切面的方式,更爽,分为前后,创建aspect包。既然是Aop,肯定要加注解(aspect,component),来和普通类分别开。
做一个切面类,拦截下所有controller下的请求。也分三个阶段,前,后,最后,这有点像钩子函数,也就是前端的生命周期函数,都是定义好的且有规定的执行顺序的功能函数。
先完善before,request获得ip和url,joinPoint对象获取类名,方法名,参数。在通过自定义的类,把这些值都传进去:
自定义的类:请求封装为一个类
完善剩下的两个:
看一下控制器:
最终的日志效果,可以看到我们想要的信息了:
#页面处理
1.首先,前端文件导入idea,将前端页面整合成符合thymeleaf规范的形式,(即最外层包名为templates,将其他文件都拉入其中)。最后把static也copy进去。
2.布局,修改一些资源引入的格式(link标签里的自定义css,以及一些js的引入,cdn的话不用管,因为是一些网络地址,网络上的都ok,也就是相对路径都需要处理),因为,要符合thymeleaf引擎的语法。利用fragment定义一些公共的页面,类似flask里的layout。写一个文件_fragment.html,里面都是一些片段。
也可以接受参数,例:th:replace表示替换整个html元素,这样就可以使得每个页面的标题都会变。
再看看具体页面的使用,这里以首页为例(~{::title})表示传入title这整个元素:
对于,th:classappend,这个的作用是在class后面能添加信息,这里是添加active,这样在点到哪个页面的时候,哪个页面就会显示激活的状态,当然,要做下判断,根据n的值,才知道是具体的哪个页面。
传入n:
通过以下方式可实现,在模板引擎里有效,在html里是注释:
3.美化,向错误页里添加footer,以及头部导航,不能只显示一个div,不然太low。
看下中间的:
美化后:
#实体类的设计
以对象来驱动。
关系:即一对多,多对多。一个用户可以写多个博客…,建立关系后,知道一个,就可以取到另一个的值。
比较特殊的:自关联(评论实体类)。