Log:log4j2.xml 配置示例和异步日志详解

Log4j2配置:log4j2.xml文件示例配置; Log4j2 官方文档

译:Log4j2 > Configuration

将日志请求插入应用程序代码需要相当大的计划和精力。观察表明,大约4%的代码用于日志记录。因此,即使是中等规模的应用程序,它们的代码中也会嵌入数千个日志语句。考虑到它们的数量,必须管理这些日志语句,而无需手动修改它们。

Log4j 2的配置可以通过以下四种方式之一完成:

  • 通过以XML、JSON、YAML或属性格式编写的配置文件。
  • 通过编程方式创建ConfigurationFactory和Configuration实现。
  • 通过调用Configuration接口中公开的API来添加组件到默认配置。
  • 通过调用内部Logger类的方法进行配置。
阅读更多

错误:java.lang.ClassNotFoundException-javax.el.ELManager

Maven 项目,pom.xml文件装配的是 tomcat7-maven-plugin插件,但项目中使用了Servlet 3.0的特性。此情况下如果项目使用Maven跑,则会报错:java.lang.ClassNotFoundException: javax.el.ELManager

javax.el.ELManager这个包在Tomcatlib库里是存在的,真实的报错原因是Tomcat 7里的该包的版本低了,满足不了项目里对Servlet 3.0特性的支持。而Servlet 3.0 + 至少需要Tomcat 8或更高的版本才能支持。

解决:因到目前为止没有Tomcat 8Maven插件,所在需要在pom.xml里添加更高版本的依赖:

1
2
3
4
5
<dependency>
<groupId>javax.el</groupId>
<artifactId>javax.el-api</artifactId>
<version>3.0.0</version>
</dependency>
阅读更多

Java基础:JSR 303校验

  JSR 303JavaBean数据合法性校验提供的一个标准规范,叫做Bean Validation,随JavaEE 6发布。官方参考实现是Hibernate Validator

  Bean ValidationJava Bean定义了相应的数据类型和API,在应用中通过在Bean属性上标注类似于@NotNull, @Max等标准的注解指定校验规则,并通过验证接口对 Bean 进行验证。

  该校验框架是一个运行时框架,在验证之后验证的错误信息被马上返回;核心接口是javax.validation.Validator,该接口根据目标对象类中所标注的校验注解进和地数据校验,并得到校验结果。

  该标准目标有两个实现:Hibernate ValidatorApache bval,使用较多的是前者。

  JSR 303官方标准:https://jcp.org/en/jsr/detail?id=303

阅读更多

Java基础:Reflection 反射机制理解

反射(Reflection)是 Java 中的一种工具,即运行态的 Java 程序可获取任意一个对象的信息,并且可以操作类或对象的内部属性(类型、属性、方法)。
  
程序中一般的对象的类型都是在编译期就确定下来的,而Java反射机制可以动态地创建对象并调用其属性,这样的对象的类型在编译期是未知的。

反射的核心是JVM在运行时才动态加载类或调用方法/访问属性,它不需要事先(写代码的时候或编译期)知道运行对象是谁。反射是相对常规的通过new来创建对象方式的反操作的称呼。

实际上,只有当程序需要动态创建某个类的对象时才会考虑使用反射,通常在开发通用性比较广的框架、基础平台时可能会大量使用反射。

阅读更多

Java基础:Java链式编程小记

  链式编程可以点点点出属性,通过返回对象本身(this)可以调用本身的属性。
  一般在创建对象并给属性赋值时使用。
  这种方式使用会越来越多,很多Apache工具如HttpClient里给RequestConfig赋值,JDK里面有些类或方法也使用,如:StringBufferappend()方法。

阅读更多