实体类一般需要重写toString()方法,在打印日志时输出参数的信息。但是如果手动拼接实体类里每个属性和属性值又比较麻烦,以下是常用的几种方法。
利用Apache工具类ToStringBuilder
//方法1 输出对象名称简写 属性 属性值(我常用这种方式)
@Override public String toString() { return ToStringBuilder.reflectionToString(this, ToStringStyle.SHORT_PREFIX_STYLE); }
如果输出信息想过滤掉某些特殊字段,如password,可以采用如下方式:
@Override public String toString() { return (new ReflectionToStringBuilder(this, ToStringStyle.SHORT_PREFIX_STYLE) { @Override protected boolean accept(Field f) { return super.accept(f) && !f.getName().equalsIgnoreCase("password"); //过滤掉特殊字段 } }).toString(); }
ToStringBuilder工具类还有以下几种显示方式:
/对象及其属性一行显示
ToStringBuilder.reflectionToString(this);
ToStringBuilder.reflectionToString(u, ToStringStyle.DEFAULT_STYLE)
//属性换行显示
ToStringBuilder.reflectionToString(u, ToStringStyle.MULTI_LINE_STYLE)
//不显示属性名,只显示属性值,在同一行显示
ToStringBuilder.reflectionToString(u, ToStringStyle.NO_FIELD_NAMES_STYLE)
//对象名称简写
ToStringBuilder.reflectionToString(u, ToStringStyle.SHORT_PREFIX_STYLE)
//不显示对象名称 只显示属性
ToStringBuilder.reflectionToString(u, ToStringStyle.SIMPLE_STYLE)
--------------------------------------------------------------------------------------------
另一种重写toString()的方法是利用反射机制,获取实体类的所有属性和方法,实现如下:
public class ToStringUtil{
/**
* 输出指定的某些字段fieldName, 如果不填则输出所有字段
* @param entity
* @param fieldName
* @return
*/
public static String toString(Entity entity, String... fieldName)
{
Class cls = entity.getClass();
StringBuffer buffer = new StringBuffer(cls.getSimpleName() + ": ");
try
{
//不获取私有方法
Method[] methods = cls.getMethods();
if(null != fieldName && fieldName.length != 0)
{
for(Method method: methods)
{
String mn = method.getName();
for(String fn: fieldName)
{
if(mn.equalsIgnoreCase("get" + fn))
{
String value = method.invoke(entity).toString();
buffer.append(mn + "=" + value + " &");
}
}
}
}
else
{
//得到所有field
Field[] fields = cls.getDeclaredFields();
for(Method method: methods)
{
String mn = method.getName();
for(Field field: fields)
{
String name = field.getName().toString();
if(mn.equalsIgnoreCase("get" + name))
{
String value = method.invoke(entity).toString();
buffer.append(name + "=" + value + " &");
}
}
}
}
}
catch(Exception e)
{
e.printStackTrace();
}
return buffer.substring(0, buffer.length()-1).toString();
}
}