spring boot空属性赋值问题与aspect日志实现方法

 更新时间:2020年08月06日 09:58:14   作者:jigsaw6213  
这篇文章主要介绍了spring boot空属性赋值问题与aspect日志实现方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

空属性赋值问题

MyBeanUtils类

public class MyBeanUtils {
 
 public static String[] getNullPropertyNames(Object source){
  BeanWrapper beanWrapper=new BeanWrapperImpl(source);
  PropertyDescriptor[] pds=beanWrapper.getPropertyDescriptors();
  List<String> nullPropertyNames=new ArrayList<>();
  for (PropertyDescriptor pd:pds){
   String propertyName=pd.getName();
   if(beanWrapper.getPropertyValue(propertyName)==null){
    nullPropertyNames.add(propertyName);
   }
  }
  return nullPropertyNames.toArray(new String[nullPropertyNames.size()]);
 }
}

在NewServiceImpl中对updateNew方法进行修改

@Override
 public News updateNew(Long id, News news) {
  News news1=newRepository.findById(id).orElse(null);
  if(news1==null){
  //  System.out.println("未获得更新对象");
   throw new NotFoundException("该新闻不存在");
  }
  //更新后传入的news复制给news1,查找更新数据news中空值属性,忽略不复制给news1
  BeanUtils.copyProperties(news,news1, MyBeanUtils.getNullPropertyNames(news));
  news1.setUpdateTime(new Date());
  return newRepository.save(news1);
 }

日志打印

新建一个LogAspect类

@Aspect
@Component
public class LogAspect {

 private final Logger logger= LoggerFactory.getLogger(this.getClass());

 @Pointcut("execution(* com.zr0726.news.web.*.*(..))")
 public void log(){}

 @Before("log()")
 public void doBefore(JoinPoint joinPoint){
  //获得request
  ServletRequestAttributes attributes=(ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
  HttpServletRequest request=attributes.getRequest();
  //获得url和ip
  String url=request.getRequestURL().toString();
  String ip=request.getRemoteAddr();
  String classMethod=joinPoint.getSignature().getDeclaringTypeName()+"."+joinPoint.getSignature().getName();
  Object[] args=joinPoint.getArgs();
  Requestlog requestlog=new Requestlog(url,ip,classMethod,args);
  logger.info("_____________________doBefore_______________________");
 }

 @After("log()")
 public void doAfter(){
  logger.info("_____________________doAfter_______________________");
 }

 @AfterReturning(returning = "result",pointcut = "log()")
 public void adAfterReturn(Object result){
  logger.info("Result: {}",result);
 }
 
 private class Requestlog{
  private String url;
  private String ip;
  private String classMethod;
  private Object[] args;

  public Requestlog(String url, String ip, String className, Object[] args) {
   this.url = url;
   this.ip = ip;
   this.classMethod = className;
   this.args = args;
  }

  @Override
  public String toString() {
   return "Requestlog{" +
     "url='" + url + '\'' +
     ", ip='" + ip + '\'' +
     ", classMethod='" + classMethod + '\'' +
     ", args=" + Arrays.toString(args) +
     '}';
  }
 }
}

效果展示

在这里插入图片描述

总结

到此这篇关于spring boot空属性赋值问题与aspect日志实现方法的文章就介绍到这了,更多相关spring boot空属性赋值内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:

相关文章

  • Spring Boot JPA Repository之existsBy查询方法失效的解决

    Spring Boot JPA Repository之existsBy查询方法失效的解决

    这篇文章主要介绍了Spring Boot JPA Repository之existsBy查询方法失效的解决方法,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-06-06
  • Java强制类型转换原理详解(父类转子类、子类转父类)

    Java强制类型转换原理详解(父类转子类、子类转父类)

    这篇文章主要给大家介绍了关于Java强制类型转换原理(父类转子类、子类转父类)的相关资料,所谓的强制类型转换,其实是自动类型转换的逆过程,在数据类型兼容的情况下,将容量大的数据类型转换为容量小的数据类型,需要的朋友可以参考下
    2023-12-12
  • jdk17 SpringBoot JPA集成多数据库的示例详解

    jdk17 SpringBoot JPA集成多数据库的示例详解

    这篇文章主要介绍了jdk17 SpringBoot JPA集成多数据库的示例代码,包括配置类、请求拦截器、线程上下文等相关知识,代码简单易懂,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-08-08
  • Java数据结构学习之栈和队列

    Java数据结构学习之栈和队列

    这篇文章主要介绍了Java数据结构学习之栈和队列,文中有非常详细的代码示例,对正在学习java的小伙伴们有一定的帮助,需要的朋友可以参考下
    2021-05-05
  • SpringBoot整合redis+lettuce的方法详解

    SpringBoot整合redis+lettuce的方法详解

    这篇文章主要介绍了SpringBoot整合redis+lettuce的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-08-08
  • springboot解决Class path contains multiple SLF4J bindings问题

    springboot解决Class path contains multiple 

    这篇文章主要介绍了springboot解决Class path contains multiple SLF4J bindings问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-07-07
  • Collection stream使用示例详解

    Collection stream使用示例详解

    这篇文章主要介绍了Collection stream使用示例,stream流几乎可以完成对集合的任意操作,映射、去重、分组、排序、过滤等
    2022-12-12
  • MVC+DAO设计模式下的设计流程详解

    MVC+DAO设计模式下的设计流程详解

    这篇文章主要介绍了MVC+DAO设计模式下的设计流程详解,分别介绍了数据库设计、设计符合java bean标准的entity类、设计访问数据库的DAO接口等内容,具有一定参考价值,需要的朋友可以了解下。
    2017-11-11
  • Spring集成Web环境的实例详解

    Spring集成Web环境的实例详解

    这篇文章主要介绍了Spring集成Web环境,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-02-02
  • 基于Java语言开发的一个高效的敏感词过滤工具

    基于Java语言开发的一个高效的敏感词过滤工具

    这篇文章主要为大家详细介绍了如何基于Java语言开发的一个高效的敏感词过滤工具,文中的示例代码简洁易懂,有需要的小伙伴可以参考一下
    2025-01-01

最新评论