edm项目5.3总结

一、lombok的使用

maven引入

    <dependency>
		<groupId>org.projectlombok</groupId>
		<artifactId>lombok</artifactId>
		<version>1.18.6</version>
		<scope>provided</scope>
	</dependency>

场景一、使用log打印日志

@RunWith(SpringRunner.class)
@SpringBootTest
@Slf4j
public class MailProducerApplicationTests {

    @Test
    public void contextLoads() {
        log.info("hello world!");
    }

}

场景二、DTO上使用

使用@Data,不需要再手动生成getter setter toString hsahCode等方法

import javax.validation.constraints.NotEmpty;

@Data
public class MailSendDTO {
    @NotEmpty
    private String sendTo;

    @NotEmpty
    private String sendMail;

    @NotEmpty
    private String sendContent;

    @NotEmpty
    private Long sendPriority;
}

其他场景

单独使用@Getter @Setter @ToString等更精细的注解;@Cleanup可以用于关闭流;

二、应用AOP为每个接口织入日志代码

maven依赖

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-aop</artifactId>
        </dependency>

日志代码

@Aspect
@Component
@Slf4j
public class WebLogAspect {
    @Pointcut("execution(public * com.hgc.*.api.*.*(..))")
    public void logPointCut() {

    }

    @Around("logPointCut()")
    public Object around(ProceedingJoinPoint point) throws Throwable {
        //打印接口信息
        ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.currentRequestAttributes();
        HttpServletRequest request = attributes.getRequest();
        log.info("---------------request start---------------");
        log.info("url={}",request.getRequestURL());
        log.info("method={}",request.getMethod());
        log.info("class_method={}", point.getSignature().getDeclaringTypeName() + "." + point.getSignature().getName());
        log.info("args={}", point.getArgs());

        long beginTime = System.currentTimeMillis();
        Object result = point.proceed();
        long time = System.currentTimeMillis() - beginTime;

        log.info("response={}", FastJsonConvertUtil.convertObjectToJSON(result));
        log.info("cost time={}",time);
        log.info("---------------request end---------------");
        return result;
    }
}

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值