|
类似spring xml, |
|
|
没有人回答吗
|
|
|
文本内容解析为对象,用严格的xml方式,或者Json方式都可以吧。
你的文本对象内容是什么样子的? |
|
5分 |
这个你必需这样做,没有其它更好的办法,当然,你可以下载一个xstram的工具包来帮你完成转换过程。
|
5分 |
内省拿到属性的类型之后
可以用beanutils框架的ConvertUtils.convert方法将你读到的值转换为属性的类型 |
5分 |
public static void main(String[] args) {
Map<String, String> params = new HashMap<String, String>();
Object bean = new Object();
Class<?> clazz = bean.getClass();
Field[] fields = clazz.getDeclaredFields();
for (Field field : fields) {
try {
String fieldName = field.getName();
Class<?> type = field.getType();
String methodName = "set"
+ fieldName.substring(0, 1).toUpperCase()
+ fieldName.substring(1);
Method method = clazz.getMethod(methodName, type);
String typeName = type.getName();
if (typeName.startsWith("["))
continue;
Constructor<?> constructor = type.getConstructor(String.class);
String paramt = params.get(fieldName);
Object value = constructor.newInstance(paramt);
method.invoke(bean, value);
} catch (NoSuchMethodException e) {
} catch (SecurityException e) {
} catch (InstantiationException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
} catch (IllegalArgumentException e) {
e.printStackTrace();
} catch (InvocationTargetException e) {
e.printStackTrace();
}
}
}
|
|
目前只支持原始类型赋值,抛砖引玉,其他的自己实现。
|
|
|
<?xml version=”1.0″ encoding=”UTF-8″?> 这种格式,通过反射可以转换为对象,主要是赋值出问题,说string不能cast to |
|
|
恩,谢谢,知道有个xstream,可以转对象,主要想学习学习反射这块,谢谢 |
|
|
谢谢,我看看。。。 |
|
|
自动转换这个东西会害人的。比如95,你觉得他就一定是整型的么?为什么不是字符串呢? |
|
|
1.通过spring的xml加载可以自动加载成对应javabean。
2. <?xml version="1.0" encoding="UTF-8"?> <beans> <bean id="test" class="com.test.testVO"> <attr> <value id="name" type="java.lang.String">sara</value> <value id="id" type="java.lang.Long">4</value> <value id="score"type="java.lang.Integer" >95</value> </attr> </bean> </beans> 通过配置type属性,知道参数的类型,可直接转,参照 #5. |
|
谢谢,刚才想回复,说不能连续回复三次,刚才我报错了,是我写错了,后来就对了,谢谢你。。。 |
|
那个,我只是举个例子,95不一定非得是数字,我只是想说,我从xml读取出来的是string类型的,我要为该对象赋值,可该对象属性类型不一定都是string类型的,所以想问有什么方法可以把string转为相应的类型,不然为对象赋值,会报错。。 |
|
5分 |
可以参考Spring配置bean方式,要求有setter方法的。这边有个例子:
package com.reflect.demo1;
import java.lang.reflect.Constructor;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
public class Demo1 {
public static void main(String[] args) throws ClassNotFoundException, IllegalArgumentException, SecurityException,
InstantiationException, IllegalAccessException, InvocationTargetException, NoSuchMethodException,
NoSuchFieldException {
// 省略配置文件解析过程
// 得到类路径,加载类
Class<?> clazz = Class.forName("com.reflect.demo1.Pojo1");
// 对象实例化
Object bean = clazz.newInstance();
// 属性"id"配置了值101
// 属性首字母大写,前面加set,生成setter方法
String idSetter = "setId";
Class idType = clazz.getDeclaredField("id").getType();
// 封装基本类型的String类型构造方法// 本质上就是new Integer(String)方法
Constructor idTypeCs = idType.getDeclaredConstructor(String.class);
Method idSetMethod = clazz.getDeclaredMethod(idSetter, idType);
idSetMethod.invoke(bean, idTypeCs.newInstance("101"));
// 属性"name"配置了"张三"
// 生成setter方法
String nameStter = "setName";
Class nameType = clazz.getDeclaredField("name").getType();
// 封装基本类型的String类型构造方法
Constructor nameTypeCs = nameType.getDeclaredConstructor(String.class);
Method nameSetMethod = clazz.getDeclaredMethod(nameStter, nameType);
nameSetMethod.invoke(bean, nameTypeCs.newInstance("张三"));
// 验证
Pojo1 pojo = (Pojo1) bean;
System.out.println(pojo.getId());
System.out.println(pojo.getName());
}
}
// 同一包下
class Pojo1 {
private Integer id;
private String name;
public int getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
不过只考虑了封装类型对象,想基本类型int等,如果实现,我只想到一个个的if/else了。。 |