StackLoggerImpl.java 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141
  1. package com.genersoft.iot.vmp.gb28181.conf;
  2. import gov.nist.core.StackLogger;
  3. import org.slf4j.LoggerFactory;
  4. import org.slf4j.spi.LocationAwareLogger;
  5. import org.springframework.stereotype.Component;
  6. import java.util.Properties;
  7. @Component
  8. public class StackLoggerImpl implements StackLogger {
  9. /**
  10. * 完全限定类名(Fully Qualified Class Name),用于定位日志位置
  11. */
  12. private static final String FQCN = StackLoggerImpl.class.getName();
  13. /**
  14. * 获取栈中类信息(以便底层日志记录系统能够提取正确的位置信息(方法名、行号))
  15. * @return LocationAwareLogger
  16. */
  17. private static LocationAwareLogger getLocationAwareLogger() {
  18. return (LocationAwareLogger) LoggerFactory.getLogger(new Throwable().getStackTrace()[4].getClassName());
  19. }
  20. /**
  21. * 封装打印日志的位置信息
  22. * @param level 日志级别
  23. * @param message 日志事件的消息
  24. */
  25. private static void log(int level, String message) {
  26. LocationAwareLogger locationAwareLogger = getLocationAwareLogger();
  27. locationAwareLogger.log(null, FQCN, level, message, null, null);
  28. }
  29. /**
  30. * 封装打印日志的位置信息
  31. * @param level 日志级别
  32. * @param message 日志事件的消息
  33. */
  34. private static void log(int level, String message, Throwable throwable) {
  35. LocationAwareLogger locationAwareLogger = getLocationAwareLogger();
  36. locationAwareLogger.log(null, FQCN, level, message, null, throwable);
  37. }
  38. @Override
  39. public void logStackTrace() {
  40. }
  41. @Override
  42. public void logStackTrace(int traceLevel) {
  43. System.out.println("traceLevel: " + traceLevel);
  44. }
  45. @Override
  46. public int getLineCount() {
  47. return 0;
  48. }
  49. @Override
  50. public void logException(Throwable ex) {
  51. }
  52. @Override
  53. public void logDebug(String message) {
  54. log(LocationAwareLogger.INFO_INT, message);
  55. }
  56. @Override
  57. public void logDebug(String message, Exception ex) {
  58. log(LocationAwareLogger.INFO_INT, message, ex);
  59. }
  60. @Override
  61. public void logTrace(String message) {
  62. log(LocationAwareLogger.INFO_INT, message);
  63. }
  64. @Override
  65. public void logFatalError(String message) {
  66. log(LocationAwareLogger.INFO_INT, message);
  67. }
  68. @Override
  69. public void logError(String message) {
  70. log(LocationAwareLogger.INFO_INT, message);
  71. }
  72. @Override
  73. public boolean isLoggingEnabled() {
  74. return true;
  75. }
  76. @Override
  77. public boolean isLoggingEnabled(int logLevel) {
  78. return true;
  79. }
  80. @Override
  81. public void logError(String message, Exception ex) {
  82. log(LocationAwareLogger.INFO_INT, message, ex);
  83. }
  84. @Override
  85. public void logWarning(String message) {
  86. log(LocationAwareLogger.INFO_INT, message);
  87. }
  88. @Override
  89. public void logInfo(String message) {
  90. log(LocationAwareLogger.INFO_INT, message);
  91. }
  92. @Override
  93. public void disableLogging() {
  94. }
  95. @Override
  96. public void enableLogging() {
  97. }
  98. @Override
  99. public void setBuildTimeStamp(String buildTimeStamp) {
  100. }
  101. @Override
  102. public void setStackProperties(Properties stackProperties) {
  103. }
  104. @Override
  105. public String getLoggerName() {
  106. return null;
  107. }
  108. }