利用ReflectionToStringBuilder重写toString方法,让日志可以直接打印对象中的数据,方便跟踪问题。
1、需要引入jar包,添加maven依赖:
<dependency> <groupId>org.apache.commons</groupId> <artifactId>commons-lang3</artifactId> <version>3.1</version> </dependency>
2、为实体类添加toString方法:
public String toString() { return ReflectionToStringBuilder.toString(this, ToStringStyle.SHORT_PREFIX_STYLE); }
//输出内容示例:“User[id=2,name=张三,password=123456]”
补充说明:
ToStringStyle.SHORT_PREFIX_STYLE:表示按定义的属性名顺序输出。
ToStringStyle NO_FIELD_NAMES_STYLE:只打印值,不打印字段名。
ToStringStyle MULTI_LINE_STYLE:每个字段打印一行(上面的样式都是在同一行输出)
ReflectionToStringBuilder.toStringExclude(this, "password", "mobile");//不包括指定的属性名,防止一些敏感信息被打印到日志里
也可以通过fastjson输出JSON格式,例:
import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.serializer.SerializerFeature;
@Override public String toString() { return JSON.toJSONString(this, new SerializerFeature[]{SerializerFeature.WriteMapNullValue, SerializerFeature.WriteNullListAsEmpty, SerializerFeature.WriteNullStringAsEmpty, SerializerFeature.WriteNullNumberAsZero, SerializerFeature.WriteNullBooleanAsFalse, SerializerFeature.UseISO8601DateFormat }); }
需要引入alibaba的jar包:
<dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>1.2.4</version> </dependency>