springboot 实现自定义注解

一、创建注解接口

package com.ffcs.itco.api.annotation;

import java.lang.annotation.*;

@Documented
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
public @interface HeaderChecker {

    /**
     * Without default value means this argument is required
     *
     * @return Header names
     */
    String[] headerNames();
}

标题二、编写注解要实现的逻辑

package com.ffcs.itco.api.aspect;

import com.ffcs.itco.api.annotation.HeaderChecker;
import com.ffcs.itco.api.util.DateUtil;
import org.aspectj.lang.annotation.After;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;
import org.springframework.util.StringUtils;
import org.springframework.web.context.request.RequestContextHolder;
import org.springframework.web.context.request.ServletRequestAttributes;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.util.Objects;
import java.util.Optional;

@Aspect
@Component
public class HeaderCheckerAspect {

    private final static Logger logger = LoggerFactory.getLogger(HeaderCheckerAspect.class);

    @Before("@annotation(headerChecker)")
    public void doBefore(HeaderChecker headerChecker) {
        HttpServletRequest request = currentRequest();
        if (Objects.isNull(request)) {
            logger.info("without request, skip");
            return;
        }

        String[] headerNames = headerChecker.headerNames();
        for (String headerName : headerNames) {
            String value = request.getHeader(headerName);
            if (StringUtils.hasText(value)) {
                continue;
            }
            logger.error("Header {} is required", headerName);
            throw new IllegalArgumentException("Header " + headerName + " is required");
        }
        if(!request.getHeader("Content-Type").equals("application/json;charset=utf-8")){
            logger.error("Header {} is required", "Content-Type");
            throw new IllegalArgumentException("Header Content-Type is illegal ");
        }

        logger.info("checked");
    }

    @After("@annotation(headerChecker)")
    public void doAfter(HeaderChecker headerChecker) {
        HttpServletRequest request = currentRequest();
        //set HttpServletResponse

        HttpServletResponse response = currentResponse();
        if("200".equals(response.getStatus())){
            response.setHeader("Content-Type",request.getHeader("Content-Type"));
            response.setHeader("X-Request-ID",request.getHeader("X-Request-ID"));
            response.setHeader("Date", DateUtil.getUTCTimeStr());
        }


        logger.info("checked");
    }

    /**
     * Return request current thread bound or null if none bound.
     *
     * @return Current request or null
     */
    private HttpServletRequest currentRequest() {
        // Use getRequestAttributes because of its return null if none bound
        ServletRequestAttributes servletRequestAttributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
        return Optional.ofNullable(servletRequestAttributes).map(ServletRequestAttributes::getRequest).orElse(null);
    }

    /**
     * Return request current thread bound or null if none bound.
     *
     * @return Current request or null
     */
    private HttpServletResponse currentResponse() {
        // Use getRequestAttributes because of its return null if none bound
        ServletRequestAttributes servletRequestAttributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
        return Optional.ofNullable(servletRequestAttributes).map(ServletRequestAttributes::getResponse).orElse(null);
    }
}

三、在对应的方法上加上自定义的注解

 /**
     * 获取商品详细信息
     * @param request
     * @param req
     * @return
     */
    @AspectLog
    @HeaderChecker(headerNames = {"Content-Type", "X-Request-ID","X-APP-ID","X-APP-KEY","Date"})
    @PostMapping("/api/QueryOfferDetail")
    public Map<String,Object> getQueryOfferDetail(@RequestBody String request, HttpServletRequest req){

        Map<String,Object> resultMap = offerManageService.queryOfferDetail(request,req);

        return resultMap;
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值