目录
请求接口:
数据库表结构解析:
思路:
1、首先接收前端的文章id,通过文章id和level=1查出第一层评论列表
2、然后将查询出来的第一级评论列表遍历转换为它的vo形式返回给前端页面,遍历出来的评论对象还需再转换vo
3、遍历出来的评论对象转换vo时,需要将现在评论对象的id当做parentid以及level=2来查询有没有匹配的二级评论对象列表
4、如果有二级评论对象列表,好再重复第2步骤,重复过程中标红的改为对应的层级即可
5、如果不进行改进只能查出两层评论
总结:这个地方很绕,需要你把数据库的每个字段弄明白什么意思,再仔细揣摩一下即可明白含义。
改进:我想的是加个计数器进行累加第三步的level,具体能不能行还没取测试,如果小伙伴们有想法可以打在评论区交流
请求接口:
思路:
评论分为一级评论和二级评论,一级评论即正常发的评论,二级评论即为评论的评论
1、接收前端传过来的评论相关的参数
2、如果是一级评论,则需要将实体类的level设置为1,parentid设置为0,touid设置为0;如果是二级评论,则前端会传过parentid和touid,我们将level设置为2,parentid和touid设置为前端传递过来的参数即可
3、将设置好参数的实体类存入数据库
4、最后将评论的请求路径添加到WebMvcConfigurer的addInterCeptors方法中,实现评论的登录拦截
请求接口:
思路:
1、前端是get请求,也没带什么参数,直接去分类表里面查出所有的分类返回前端即可
请求接口:
思路:
1、直接在标签表里面查出所有的文章标签返回给前端页面即可
请求接口:
思路:
发布文章涉及到三个表:文章表、文章标签表、文章体表
1、我们接收前端发过来的发布请求,获取请求体中的参数以及当前线程的用户信息
2、将相应信息插入文章表、文章标签表、文章体表
3、最后将插入文章的文章id返回到前端页面
1、自定义日志注解
- /**
- * 日志注解
- */
- //Type代表可以放在类上面,Method代表可以放在方法上
- @Target(ElementType.METHOD)
- @Retention(RetentionPolicy.RUNTIME)
- @Documented
-
- public @interface LogAnnotation {
-
- //自定义的参数
- String module() default "";
-
- String operation() default "";
- }
2、定义切面,绑定切入点和通知,切入点就是自定义注解
- @Aspect
- @Component
- @Slf4j
- public class LogAspect {
-
-
- //1、切入点
- @Pointcut("@annotation(com.mszlu.blog.common.aop.LogAnnotation)")
- public void logPointCut() {
- }
-
- //2、通知中记录日志
- @Around("logPointCut()")
- public Object around(ProceedingJoinPoint point) throws Throwable {
- long beginTime = System.currentTimeMillis();
- //执行方法
- Object result = point.proceed();
- //执行时长(毫秒)
- long time = System.currentTimeMillis() - beginTime;
- //保存日志
- recordLog(point, time);
- return result;
- }
-
- private void recordLog(ProceedingJoinPoint joinPoint, long time) throws Exception {
- MethodSignature signature = (MethodSignature) joinPoint.getSignature();
- Method method = signature.getMethod();
- LogAnnotation logAnnotation = method.getAnnotation(LogAnnotation.class);
- log.info("=====================log start================================");
- log.info("module:{}",logAnnotation.module());
- log.info("operation:{}",logAnnotation.operation());
-
- //请求的方法名
- String className = joinPoint.getTarget().getClass().getName();
- String methodName = signature.getName();
- log.info("request method:{}",className + "." + methodName + "()");
-
- // //请求的参数
- // Object[] args = joinPoint.getArgs();
- // String params = JSON.toJSONString(args[0]);
- // log.info("params:{}",params);
-
- //获取request 设置IP地址
- HttpServletRequest request = HttpContextUtils.getHttpServletRequest();
- log.info("ip:{}", IpUtils.getIpAddr(request));
-
-
- log.info("excute time : {} ms",time);
- log.info("=====================log end================================");
- }
-
- }
3、在想记录日志的方法上,添加自定义日志注解即可实现记录日志