目前項目有個需要,就是在所有查詢的參數中,增加一個屬性。
自然想到使用 interceptor 將每個 parameter wraper 一下,加上這個屬性
我就使用 cglib 生成了一個 wrapper class,然后再 proxy 到原來的 parameter 上。
后來,出了錯誤,找了好長時間,發現
ibatis sql 中寫著 isPrimary,可其實在 java 里是這樣的
private boolean isPrimary;
public boolean isPrimary() {
return isPrimary;
}
其實屬性名字是 primary 啊,為什么在 wrapper 之前就不出錯呢。
找了一下,ibatis 是通過他自己的 probe 來獲得屬性值的,這個 probe 不僅會通過方法取值,還會通過 field name 取值,沒訪問權限的,還會加上權限。
就是 ClassInfo 的下面方法
private void addFields(Class clazz) {
Field[] fields = clazz.getDeclaredFields();
for (int i = 0; i < fields.length; i++) {
Field field = fields[i];
if (canAccessPrivateMethods()) {
try {
field.setAccessible(true);
} catch (Exception e) {
// Ignored. This is only a final precaution, nothing we can do.
}
}
if (field.isAccessible()) {
if (!setMethods.containsKey(field.getName())) {
addSetField(field);
}
if (!getMethods.containsKey(field.getName())) {
addGetField(field);
}
}
}
if (clazz.getSuperclass() != null) {
addFields(clazz.getSuperclass());
}
}
解決辦法,將 isPrimary 改成 primary
posted on 2011-06-01 15:58
哈哈的日子 閱讀(182)
評論(0) 編輯 收藏