一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - springboot 啟動項目打印接口列表的實現

springboot 啟動項目打印接口列表的實現

2021-12-28 00:51enjoy囂士 Java教程

這篇文章主要介紹了springboot 啟動項目打印接口列表的實現方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

springboot 啟動項目打印接口列表

環境

  • springboot 2.3.2.RELEASE

修改配置文件

logging:
level:
  org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping: trace

結果:

springboot 啟動項目打印接口列表的實現

 

Springboot項目添加接口入參統一打印

需求:要求接口被調用時要打印被調用方法名,以及入參情況,參數格式化時選擇fastjson

注:使用fastjson序列化時脫敏,建議入參統一使用自定義的對象類型作為入參

如果不需要參數脫敏,直接使用增強中相關代碼,并去除參數脫敏相關代碼即可

新建注解,用于實現參數打印功能的增強

@Target({ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface ParamInfo {
  /**
   * 取消統一打印參數
   * 默認為false統一打印
   * 如需自定義參數打印 請賦值為true
   */
  boolean unPrint() default false;
  /**
   * 需要脫敏的字段,如密碼等
   */
  String[] fields() default {};
}

自定義序列化規則

/**
* 序列化過濾器:值替換
*
*/
public class ReplaceFieldFilter implements ValueFilter {
  /**
   * 需要進行替換的屬性名和替換值
   * key:屬性名
   * value:替換值
   */
  private Map<String, Object> fieldMap;
  public ReplaceFieldFilter() {
  }
  public ReplaceFieldFilter(Map<String, Object> fieldMap) {
      this.fieldMap = fieldMap;
  }
  @Override
  public Object process(Object o, String name, Object value) {
      if(!CollectionUtils.isEmpty(fieldMap)){
          Iterator<Map.Entry<String, Object>> iterator = fieldMap.entrySet().iterator();
          while (iterator.hasNext()){
              Map.Entry<String, Object> next = iterator.next();
              if(next.getKey().equalsIgnoreCase(name)){
                  return next.getValue();
              }
          }
      }
      return value;
  }
  public Map<String, Object> getFieldMap() {
      return fieldMap;
  }
  public void setFieldMap(Map<String, Object> fieldMap) {
      this.fieldMap = fieldMap;
  }
  /**
   * 傳入需要脫敏的字段名,序列化時格式化為 * 號
   */
  public ReplaceFieldFilter(String... fields) {
      String str = "******";
      fieldMap = new HashMap<>(4);
      for (String field : fields) {
          fieldMap.put(field, str);
      }
  }
}

寫參數打印增強,這里選擇環繞增強

@Component
@Aspect
//表示增強的執行順序,如果多個增強,數值小的先被執行
@Order(0)
public class ParamInfoAspect {
  private static final Logger LOGGER = LoggerFactory.getLogger(ParamInfoAspect.class);
  @Around("execution(* com.service.impl.*.*(..))")
  public Object printParam(ProceedingJoinPoint joinPoint) throws Throwable {
      long startTime = System.currentTimeMillis();
      String requestId = RandomStringUtils.randomAlphanumeric(16);
      Object returnValue = null;
      try {
          Object[] args = joinPoint.getArgs();
          // 獲取方法對象
          MethodSignature signature = (MethodSignature) joinPoint.getSignature();
          Method method = signature.getMethod();
          //通過注解獲取脫敏字段,之后初始化fieldMap,完成字段脫敏
          ParamInfo annotation = method.getAnnotation(ParamInfo.class);
          Map<String, Object> fieldMap = new HashMap<>(4);
          fieldMap.put("password", "******");
          if (annotation != null) {
              //獲取需要脫敏的字段名數組
              String[] fields = annotation.fields();
              for (String field : fields) {
                  fieldMap.put(field, "******");
              }
          }
          String param;
          //參數整合,多字段入參整合為對象,單個對象入參格式不變
          if (args.length > 1 || (args.length == 1 && args[0].getClass() == String.class)) {
              Map<String, Object> paramMap = new LinkedHashMap<>();
              String[] parameterNames = signature.getParameterNames();
              for (int i = 0; i < parameterNames.length; i++) {
                  paramMap.put(parameterNames[i], args[i]);
              }
              param = "[" + JSON.toJSONString(paramMap, new ReplaceFieldFilter(fieldMap)) + "]";
          } else {
              param = JSON.toJSONString(args, new ReplaceFieldFilter(fieldMap));
          }
          String methodName = method.getName();
          LOGGER.info("method:[{}], parameter:{}, requestId:[{}]", methodName, param, requestId);
          returnValue = joinPoint.proceed();
          return returnValue;
      } catch (Exception e) {
          LOGGER.error("system is error:", e);
 //可在這里定義程序異常時的錯誤返回值
          returnValue = ErrorCode.SYSTEM_ERROR;
          return returnValue;
      } finally {
          LOGGER.info("request cost:{}ms, requestId:[{}]", System.currentTimeMillis() - startTime, requestId);
          LOGGER.info("returnValue:[{}], requestId:[{}]", returnValue, requestId);
      }
  }
}

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持服務器之家。

原文鏈接:https://enjoy-day.blog.csdn.net/article/details/115071427

延伸 · 閱讀

精彩推薦
  • Java教程小米推送Java代碼

    小米推送Java代碼

    今天小編就為大家分享一篇關于小米推送Java代碼,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧...

    富貴穩中求8032021-07-12
  • Java教程Java BufferWriter寫文件寫不進去或缺失數據的解決

    Java BufferWriter寫文件寫不進去或缺失數據的解決

    這篇文章主要介紹了Java BufferWriter寫文件寫不進去或缺失數據的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望...

    spcoder14552021-10-18
  • Java教程升級IDEA后Lombok不能使用的解決方法

    升級IDEA后Lombok不能使用的解決方法

    最近看到提示IDEA提示升級,尋思已經有好久沒有升過級了。升級完畢重啟之后,突然發現好多錯誤,本文就來介紹一下如何解決,感興趣的可以了解一下...

    程序猿DD9332021-10-08
  • Java教程20個非常實用的Java程序代碼片段

    20個非常實用的Java程序代碼片段

    這篇文章主要為大家分享了20個非常實用的Java程序片段,對java開發項目有所幫助,感興趣的小伙伴們可以參考一下 ...

    lijiao5352020-04-06
  • Java教程Java使用SAX解析xml的示例

    Java使用SAX解析xml的示例

    這篇文章主要介紹了Java使用SAX解析xml的示例,幫助大家更好的理解和學習使用Java,感興趣的朋友可以了解下...

    大行者10067412021-08-30
  • Java教程Java實現搶紅包功能

    Java實現搶紅包功能

    這篇文章主要為大家詳細介紹了Java實現搶紅包功能,采用多線程模擬多人同時搶紅包,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙...

    littleschemer13532021-05-16
  • Java教程Java8中Stream使用的一個注意事項

    Java8中Stream使用的一個注意事項

    最近在工作中發現了對于集合操作轉換的神器,java8新特性 stream,但在使用中遇到了一個非常重要的注意點,所以這篇文章主要給大家介紹了關于Java8中S...

    阿杜7482021-02-04
  • Java教程xml與Java對象的轉換詳解

    xml與Java對象的轉換詳解

    這篇文章主要介紹了xml與Java對象的轉換詳解的相關資料,需要的朋友可以參考下...

    Java教程網2942020-09-17
主站蜘蛛池模板: 久久精选视频 | 亚洲国产综合自在线另类 | 铁牛tv 在线观看 | 国内精品在线播放 | 网红思瑞一区二区三区 | 本站只有精品 | 姐姐不~不可以动漫在线观看 | 91传媒制片厂果冻有限公司 | 欧美日韩亚洲区久久综合 | 日本肥熟| 欧美日韩国产一区二区三区在线观看 | 传说之下羊妈挤羊奶网站 | 污小说免费 | 动漫女性扒开尿口羞羞漫画 | 精品久久久噜噜噜久久7 | 俄罗斯处女 | 国产尤物视频 | 糖心视频在线观看 | 久久亚洲精品AV无码四区 | 久久综合久久伊人 | 91精品啪在线观看国产老湿机 | 故意短裙公车被强好爽在线播放 | 国产成人欧美 | 国产一区私人高清影院 | 天天综合天天综合色在线 | 国产三级精品播放 | 惩罚美女妲己的尤老师 | 日本成熟| 国产高清小视频 | 日韩亚洲一区中文字幕在线 | 五月天精品视频播放在线观看 | 91啦在线视频 | 石原莉奈被店长侵犯免费 | 被教官揉了一晚上的奶小说 | 白丝女仆被啪到深夜漫画 | 亚洲AV久久久噜噜噜久久 | 四虎永久在线精品波多野结衣 | 男人的j伸到女人的屁股眼 男人吃奶动态图 | 国产美女亚洲精品久久久综合91 | 日本高清在线精品一区二区三区 | 999久久免费高清热精品 |