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

做一个企业网站多少钱外国人b站

做一个企业网站多少钱,外国人b站,qq群引流推广网站,建站软件排名Logger.error还不知道怎么传参打印?看完这个你就明白了-CSDN博客 日志使用的方式 使用e.getMessage()、e .toString() 都不会打印堆栈信息,最好直接打印e。 当使用两个参数error(String message, Throwable t),且第二个参数为Throwable(就是…

Logger.error还不知道怎么传参打印?看完这个你就明白了-CSDN博客

日志使用的方式

  • 使用e.getMessage()、e .toString() 都不会打印堆栈信息,最好直接打印e。

  • 当使用两个参数error(String message, Throwable t),且第二个参数为Throwable(就是catch的的exception e)时,才会将完整的异常堆栈(就是显示哪一行出了问题,而不是只是输出报什么错)打印出来

  • 使用多个参数的error方法时,如果需要包含e参数,要把e参数放在末尾,才会完整的打印出错误堆栈信息。如:Logger.error("打印1{},打印2{},异常信息: ",123,“456”,e)。

以后写代码一定报错输出一定要先打印出日志的prefix,要不看日志都不知道是啥哪个报文出问题

java Logger.error打印错误异常的详细堆栈信息-CSDN博客

使用Logger.error(e)、Logger.error(e.getMessage())、Logger.error(“some msg” + e)、Logger.error(“some msg” + e.getMessage()) 都是调用的error(Object message),这个方法都会将入参当作Object输出,不会打印堆栈信息。
在使用Logger.error("first param ",e)时会调用error(String message, Throwable t),此方法会完整的打印出错误堆栈信息。

通常情况下,我们都是使用Logger所在的类的名称来作为Logger的名称

示例:

public class TestLogError {

public static final Logger log = LoggerFactory.getLogger(TestLogError.class);

public class test {

public class test { public static final Logger LOGGER = LogManager.getLogger(test.class);

两种使用的区别

maven项目构建以及原因:

使用maven的原因:因为使用maven,会使得项目管理比较容易。

团队中某一人新导入了一个jar包,如果没有maven,他则需要给团队中每个人拷贝一个jar包,并提示他们添加jar包到项目中,如果有maven,他则需要提示团队中的人更新一下pom.xml文件,maven则会帮你把相关jar包都完美地添加到项目中。

新建maven项目

通过idea建立maven项目_ideal只想创建一个有pom文件的maven项目-CSDN博客

普通项目变成maven项目:

1.暴力

普通java web项目转为maven项目_java项目改成maven项目-CSDN博客

2.推荐,引入maven后会生成一个pom.xml文件和对应的目录结构(但是需要自己新增配置文件)

3步将普通Java项目转成maven项目(IntelliJ IDEA)_怎樣將一個新建的普通java項目手動變成一個maven項目-CSDN博客

在IDEA中创建properties配置文件_idea创建properties配置文件-CSDN博客

import org.apache.log4j.Logger;
import org.apache.log4j.PropertyConfigurator;/*** @author hw* @PROJECT_NAME:* @DESCRIPTION:*/
public class Test {public static final Logger LOGGER = org.apache.log4j.Logger.getLogger(Test.class);
//    在代码中显式指定 log4j 配置文件的路径:static {PropertyConfigurator.configure("src/main/resources/Test.properties");}public static void main(String[] args) {try{// 模拟空指针异常//Integer nullInt = Integer.valueOf(null);int[] array = {1,2,3,4,5};int outBoundInt = array[5];}catch (Exception e){// 直接打印,则只输出异常类型LOGGER.error(e);// 使用字符串拼接LOGGER.error("使用 + 号连接直接输出 e : " + e);LOGGER.error("使用 + 号连接直接输出 e.getMessage() : " + e.getMessage());LOGGER.error("使用 + 号连接直接输出 e.toString() : " + e.toString());// 使用逗号分隔,调用两个参数的error方法LOGGER.error("使用 , 号 使第二个参数作为Throwable : ", e);// 尝试使用分隔符,第二个参数为Throwable,会发现分隔符没有起作用,第二个参数的不同据,调用不同的重载方法LOGGER.error("第二个参数为Throwable,使用分隔符打印 {} : ", e);}}
}
注意:如果配置文件命名是log4j.properties就不需要指定路径了

如图:

输出到控制台:

pom文件:可以在先在代码里面import class时候再去点击代码里面的import 想学习,就会显示提示add depencies
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>groupId</groupId><artifactId>test</artifactId><version>1.0-SNAPSHOT</version><properties><maven.compiler.source>8</maven.compiler.source><maven.compiler.target>8</maven.compiler.target></properties><dependencies><dependency><groupId>log4j</groupId><artifactId>log4j</artifactId><version>1.2.17</version></dependency></dependencies>
<!--    确保项目构建时将 log4j.properties 文件包含在最终的 JAR 或 WAR 文件中。--><build><resources><resource><directory>src/main/resources</directory><includes><include>**/*.properties</include></includes></resource></resources></build></project>

配置文件:

# 设置根日志级别为 INFO
log4j.rootLogger=INFO, console
# 这一行设置了根日志记录器的日志级别为 INFO,并指定了一个名为 "console" 的 appender。这意味着只有 INFO 及以上级别的日志会被记录,并且这些日志会通过 "console" appender 输出。# 定义控制台日志记录器
log4j.appender.console=org.apache.log4j.ConsoleAppender
# 这一行定义了一个名为 "console" 的 appender,类型为 `org.apache.log4j.ConsoleAppender`。这个 appender 会将日志输出到控制台。# 设置控制台日志记录器的目标
log4j.appender.console.Target=System.out
# 这一行指定了 "console" appender 的目标为 `System.out`,即标准输出流,也就是控制台。# 设置日志布局
log4j.appender.console.layout=org.apache.log4j.PatternLayout
# 这一行设置了 "console" appender 的布局格式为 `org.apache.log4j.PatternLayout`,允许自定义日志的输出格式。# 设置日志格式
log4j.appender.console.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n
# 这一行定义了日志的具体输出格式:
# - `%d{yyyy-MM-dd HH:mm:ss}`:日期和时间格式,例如 "2023-10-01 12:34:56"。
# - `%-5p`:日志级别,左对齐,宽度为 5 个字符,例如 "INFO "。
# - `%c{1}`:日志记录器的名称,只显示最后一级,例如 "Test"。
# - `%L`:日志记录的行号,例如 "123"。
# - `%m`:

一般都设置同时输出到控制台和文件:
# 设置根日志级别为 INFO,日志通过 console 和 file 两个 appender 输出
log4j.rootLogger=INFO,console,file# 定义控制台日志记录器
log4j.appender.console=org.apache.log4j.ConsoleAppender
log4j.appender.console.Target=System.out
log4j.appender.console.layout=org.apache.log4j.PatternLayout
log4j.appender.console.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n# 定义文件日志记录器
log4j.appender.file=org.apache.log4j.FileAppender
log4j.appender.file.File=logs/app.log  # 输出到文件 logs/app.log
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n

 Appenders 必须存在,否则根日志记录器就没有输出目标,日志消息就无法被处理。

没有app.log就会自动新建一个,这个文件是自定义的,如图

log4j.rootLogger=INFO,console,file2
log4j.appender.file2=org.apache.log4j.FileAppender
#默认输出到当前项目根目录下的 logs/app.log 文件中
log4j.appender.file2.File=logs/app.log  # 输出到文件 logs/app.log
log4j.appender.file2.layout=org.apache.log4j.PatternLayout
这几个属性是必备的,没有就没法输出

拓展:

为什么配置文件要放在 classpath 中?

  • 自动加载Log4j 会自动加载类路径中的配置文件,无需额外的配置或代码。只要配置文件位于类路径下,Log4j 会自动加载它。
  • 可移植性:当项目被打包成 JAR 或 WAR 文件时,配置文件依然会被包含在其中并可被读取。
  • 环境独立性:你可以根据不同的环境(如开发、测试、生产)提供不同的配置文件。通过不同的类路径配置文件,Log4j 可以在不同的环境中使用不同的日志策略。

拓展:
C:\path\to\libs\* 表示 C:\path\to\libs 目录下的所有 JAR 文件。这是 Java 类路径(Classpath)的一种常见表示方式,用于告诉 JVM 或编译器在指定目录下查找所有的 JAR 文件。
至于为什么不能是 WAR 文件:
文件格式不同:
JAR 文件:Java Archive 文件,用于打包 Java 类文件、资源文件等。JAR 文件可以被 JVM 直接加载和使用。
WAR 文件:Web Application Archive 文件,用于打包 Web 应用程序,包括 JSP、HTML、JavaScript、CSS 文件以及 JAR 文件等。WAR 文件通常部署在应用服务器(如 Tomcat、Jetty)上,而不是直接被 JVM 加载

public class Test {
    public static final Logger LOGGER = org.apache.log4j.Logger.getLogger(StringBufferExample.class);
修改一开始加载的文件,日志就会显示别的文件名

点击getlogger方法可以看到有很多重载方式;

http://www.ds6.com.cn/news/34485.html

相关文章:

  • 有没有专门做二手车网站怎么免费创建自己的网站
  • 网站建设saas排名优化防控措施
  • 广告设计专业就业方向谷歌seo推广
  • 网站qq客服怎么做想做电商怎么入手
  • 响应式网站文章公司推广方法有哪些
  • 关于茶网站模板怎么做推广和宣传
  • 山西做网站多少钱百度搜索引擎seo
  • 目前最好的免费网站站长工具外链查询
  • 保定 营销型网站建设谷歌外链代发
  • wordpress 链接打不开夫唯seo怎么样
  • 芜湖网站建设哪家好app推广工作是做什么的
  • 企业网站功能清单网络媒体广告代理
  • 龙岗微信网站制作黄山网站建设
  • nas搭建wordpress博客网站深圳搜狗seo
  • 学校学生网站模板下载seo排名优化方法
  • 重庆做网站人才长尾关键词挖掘工具
  • 台州招聘网站建设阿里云搜索引擎入口
  • 网站建设计划谷歌推广seo
  • 桂林有哪些做网站的电话怎么做电商生意
  • 重庆网站建设找承越91关键词
  • 漂流瓶做任务网站seo矩阵培训
  • 当前网站开发用什么软件武汉seo优化排名公司
  • 兰州 电子 网站建设上海seo优化公司
  • 网站建设怎么建设一个产品的营销方案
  • wordpress knowall主题衡水网站seo
  • 用ps做网站页面seo技术培训泰州
  • 自己做一个音乐网站怎么做成人教育培训机构
  • 小公司网站建设费用友情链接查询结果
  • 网站建设工资 优帮云企业培训课程ppt
  • 网站如何做传输网盘软文广告是什么意思