当前位置: 首页 > news >正文

淘宝网站建设设计模板网站信息化建设什么意思

淘宝网站建设设计模板,网站信息化建设什么意思,中国十大网络公司排行榜,下载图片的网站建设我们在使用 Spring5 的过程中会出现这样的现像#xff0c;就是 Spring5 内部代码打印的日志和我们自己的业务代码打印日志使用的不是统一日志实现#xff0c;尤其是在项目启动的时候#xff0c;Spring5 的内部日志使用的是 log4j2#xff0c;但是业务代码打印使用的可能是 …我们在使用 Spring5 的过程中会出现这样的现像就是 Spring5 内部代码打印的日志和我们自己的业务代码打印日志使用的不是统一日志实现尤其是在项目启动的时候Spring5 的内部日志使用的是 log4j2但是业务代码打印使用的可能是 logback log4j1 或者 其他日志实现 一、Spring4 采用日志是 commons-logging 二、Spring5 内部日志 1.Spring5 内部日志原理 Spring5 自己在 commons-logging 基础上进行修改将修改完的代码单独封装为一个 jar 包Spring5 内部就使用这个jar我们可以注意一下当我们导入 Spring5 的相关 jar 包的时候maven会为我们自动依赖一个 spring-jcl 的jar包这就是那个jar包。 可以看出这这两 jar 包的包名都起的一模一样只是LogFactory的实现是Spring5自己实现的。 2. Spring5 日志关键源码分析 org.apache.commons.logging.LogFactory#getLog(java.lang.String) /*** Convenience method to return a named logger.* param name logical name of the codeLog/code instance to be returned*/public static Log getLog(String name) {return LogAdapter.createLog(name);} org.apache.commons.logging.LogAdapter#createLog private static final String LOG4J_SPI org.apache.logging.log4j.spi.ExtendedLogger;private static final String LOG4J_SLF4J_PROVIDER org.apache.logging.slf4j.SLF4JProvider;private static final String SLF4J_SPI org.slf4j.spi.LocationAwareLogger;private static final String SLF4J_API org.slf4j.Logger;private static final LogApi logApi;static { //LOG4J_SPI org.apache.logging.log4j.spi.ExtendedLogger在Log4j2包log4j-api中 //LOG4J_SLF4J_PROVIDER // org.apache.logging.slf4j.SLF4JProvider在Log4j2桥接器包log4j-to-slf4j中 //SLF4J_SPI org.slf4j.spi.LocationAwareLogger 在slf4j包 slf4j-api 中 //SLF4J_API org.slf4j.Logger 在slf4j包 slf4j-api 中//判断是否导入了 log4j2包 log4j-apiif (isPresent(LOG4J_SPI)) {if (//判断是否导入了 Log4j2 桥接器包log4j-to-slf4jisPresent(LOG4J_SLF4J_PROVIDER) //判断是否导入了 slf4j包 slf4j-apiisPresent(SLF4J_SPI)) {// log4j-to-slf4j bridge - well rather go with the SLF4J SPI;// however, we still prefer Log4j over the plain SLF4J API since// the latter does not have location awareness support.logApi LogApi.SLF4J_LAL;}else {// Use Log4j 2.x directly, including location awareness supportlogApi LogApi.LOG4J;}}else if (isPresent(SLF4J_SPI)) {// Full SLF4J SPI including location awareness supportlogApi LogApi.SLF4J_LAL;}else if (isPresent(SLF4J_API)) {// Minimal SLF4J API without location awareness supportlogApi LogApi.SLF4J;}else {// java.util.logging as defaultlogApi LogApi.JUL;}}// LOG4J 采用 log4j2的 日志实现// SLF4J_LAL 采用 slf4j Slf4jLocationAwareLog Full SLF4J SPI //including location awareness support// SLF4J 采用 slf4j Slf4jLog Minimal SLF4J API without //location awareness supportprivate enum LogApi {LOG4J, SLF4J_LAL, SLF4J, JUL}public static Log createLog(String name) {switch (logApi) {case LOG4J:return Log4jAdapter.createLog(name);case SLF4J_LAL:return Slf4jAdapter.createLocationAwareLog(name);case SLF4J:return Slf4jAdapter.createLog(name);default:// Defensively use lazy-initializing adapter class here as well since the// java.logging module is not present by default on JDK 9. We are requiring// its presence if neither Log4j nor SLF4J is available; however, in the// case of Log4j or SLF4J, we are trying to prevent early initialization// of the JavaUtilLog adapter - e.g. by a JVM in debug mode - when eagerly// trying to parse the bytecode for all the cases of this switch clause.return JavaUtilAdapter.createLog(name);} }
http://www.yayakq.cn/news/3156/

相关文章:

  • 外贸网站制作时间及费用桂林网站制作公司
  • 在线学习建设网站正规的网站制作在哪里
  • 国内视频网站域名做任务兼职赚钱的网站有哪些
  • 酷万网站建设小程序appid
  • 园林景观设计案例网站软件开发成本估算表
  • 外贸网站推广教程北京设计机构
  • 网站备案幕布尺寸个人简历模板范文手写
  • 做传销网站的网页制作总结报告
  • 放图片网站怎样做古玩网站
  • 优秀网站优点php wap网站源码
  • uc网页浏览器网页版视频优化网站怎么做
  • 保定网站关键词优化好用的网站开发软件
  • 滨州企业做网站电子商务与网站建设实践论文
  • 网站样板我厂有大量手袋订单外发
  • 建站平台与建站系统服务网络推广
  • 一起做网店 17货源网seo查询什么意思
  • 网站功能方案广州最新进展
  • 工信部备案网站打不开wordpress右侧链接
  • 自学网站开发需要看什么书成都网站网页制作
  • 哈尔滨的建设信息网站建网站能多少带宽
  • 电子商务网站规划与建设论文建设工程网站教程
  • sharepoint做门户网站上传的网站打不开 index.asp
  • 贵阳网站制作服务商微信存储wordpress
  • 网站建设购销合同配件网站模板
  • 设计网站设计网站东营房产网信息网
  • 租服务器的网站wordpress全部教程
  • 佛山模板网站建设鄂州第一官方网站
  • 安徽网站建设科技网站seo注意事项
  • 网站优化 情况给房地产公司做网站的公司
  • 学校网站建设的技术方案怎么在门户网站上发布