java.lang.NoSuchMethodException: com.sun.proxy.$Proxy58.list錯誤解決辦法
java.lang.NoSuchMethodException: com.sun.proxy.$Proxy58.list錯誤解決辦法
玩web的SSH總會有些令你意想不到的exception,這里其中有很多事自己不小心,或者馬虎所造成。因此,解決的方案會各有不同,別人出現的異常解決方案對你的可能無效,就像上面的我報的異常一樣,百度了很多很多次,給我的答案無非就是在aop上加上一句,但是非常抱歉,我加上去無效!所以還是那句話,對于自己的異常,還是要自己解決。
首先說明一下,我這次的練習的ssh結構和異常所報的原因。
用的框架式struts2.2+hibernate4.2+spring4.0,容器室tomcat7.0.在Action中,我寫了一個基類BaseAction,繼承了ActionSupport,實現了ModelDriven接口,代碼如下:
----------
@Component
@Transactional
----------
public abstract class BaseAction<T> extends ActionSupport implements ModelDriven<T> {
private static final long serialVersionUID = 2719688501307297741L;
@Resource(name = "roleServiceImpl")
protected RoleService roleService;
@Resource(name = "departmentService")
protected DepartmentService departmentService;
@Resource(name = "userService")
protected UserService userService;
protected T model;
public BaseAction() {
ParameterizedType pt = (ParameterizedType) this.getClass().getGenericSuperclass();
@SuppressWarnings("unchecked")
Class<T> clazz = (Class<T>) pt.getActualTypeArguments()[0];
try {
model = clazz.newInstance();
} catch (Exception e) {
throw new RuntimeException(e);
}
}
public T getModel() {
return model ;
}
}
這樣做的好處是,每個組件對應的Action中只需要告訴BaseAction自己要實現的泛型,然后只需要完成自己的邏輯。對于每個Action要實現ActionSupport來講,這是一項基本的且容易想到的方案。
然后,在每個Action中調用service組件實現自己的功能,在每個Action中都使用了@Component(“departmentAction”),@Scope(“prototype”)注解,但是練習一測試,就會出現Java.lang.NoSuchMethodException: com.sun.proxy.$Proxy58.list()異常,檢查之后發(fā)現,原因是:
BaseAction是抽象的,在上面加了@Transactional是沒有意義的,
而@Transactional就是有spring管理,spring管理的對象要生成代理,而對于一個抽象的類,是不能被new成對象的,只有一個抽象類的具體實現類才有可能是被spring代理。
所以,去掉BaseAction上面的@Transactional,就是本題的原因了。
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關文章
解決Java壓縮zip異常java.util.zip.ZipException:duplicate entry
這篇文章主要介紹了解決Java壓縮zip異常java.util.zip.ZipException:duplicate entry:問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-12-12

