Struts 2具有隐式类型转换,它负责用户输入的params类型转换,例如int,string,double,boolean等 但我的要求是将富文本区域输入转换为字节数组,为此我创建了一个自定义类型转换器类。
public class StringToByteArrayConverter extends StrutsTypeConverter{
@Override
public Object convertFromString(Map context, String[] value, Class arg2) {
String val = value[0];
return val.getBytes() ;
}
@Override
public String convertToString(Map context, Object value) {
ByteArrayOutputStream out = new ByteArrayOutputStream();
ObjectOutputStream os;
try {
os = new ObjectOutputStream(out);
os.writeObject(value);
return new String(out.toByteArray());
} catch (IOException e) {
e.printStackTrace();
return null;
}
}
}
在模型类中,我在属性的setter上指定了以下注释
@TypeConversion(converter="org.package.name.StringToByteArrayConverter")
public void setVarName(byte[] varName) {
this.varName = varName;
}
同样的注释也适用于getter方法。 现在一切都很好我在Action方法中获得了正确的数据。但是在jsp上显示数据时,我会得到一些带有原始内容的额外符号。
例如。用户输入是:你的名字是什么? 它显示在jsp上:¬íur[B¬óTàxp你的名字是什么?
任何人都有任何想法,我错了什么?
答案 0 :(得分:1)
首先在字节到字符串处理中指定正确的字符集:
val.getBytes(); // wrong
val.getBytes("UTF-8"); // right
假设您正在使用UTF-8。否则,只需使用您正在使用的字符集,但从不使用val.getBytes();
,它将使用平台默认字符集,这可能与您应用的字符集不同,转换错误和工件,例如您现在获得的工具。
然后ObjectOutputStream
并没有说服我。尝试使用简单的
@Override
public String convertToString(Map context, Object value) {
try {
return new String((byte[]) value, "UTF-8");
} catch (Exception e) {
e.printStackTrace();
return null;
}
}
并最终添加错误用法的日志记录,例如:if (value instanceof byte[]).. else LOG.warn...
。