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

所属分类: 软件编程 / java 阅读数: 72
收藏 0 赞 0 分享

空属性赋值问题

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) +
     '}';
  }
 }
}

效果展示

在这里插入图片描述

更多精彩内容其他人还在看

JavaWeb项目部署到服务器详细步骤详解

这篇文章主要介绍了JavaWeb项目如何部署到服务器,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0 赞 0 分享

IDEA基于支付宝小程序搭建springboot项目的详细步骤

这篇文章主要介绍了IDEA基于支付宝小程序搭建springboot项目的详细步骤,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享

详解SpringBoot应用服务启动与安全终止

这篇文章主要介绍了SpringBoot应用服务启动与安全终止,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0 赞 0 分享

Spring Boot启动及退出加载项的方法

这篇文章主要介绍了Spring Boot启动及退出加载项的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0 赞 0 分享

Spring Data Jpa 自动生成表结构的方法示例

这篇文章主要介绍了Spring Data Jpa 自动生成表结构的方法示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0 赞 0 分享

IDEA中osgi的开发应用指南详解

这篇文章主要介绍了IDEA中osgi的开发应用指南详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享

详解用maven将dubbo工程打成jar包运行

这篇文章主要介绍了详解用maven将dubbo工程打成jar包运行,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0 赞 0 分享

详解Java合并数组的两种实现方式

这篇文章主要介绍了Java合并数组的两种实现方式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0 赞 0 分享

使用Jenkins Pipeline自动化构建发布Java项目的方法

这篇文章主要介绍了使用Jenkins Pipeline自动化构建发布Java项目的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享

使用Maven配置Spring的方法步骤

这篇文章主要介绍了使用Maven配置Spring的方法步骤,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享
查看更多