在mybatis3的MappedStatement类中有个public BoundSql getBoundSql(Object parameterObject)方法,我希望该方法在运行时返回我生成的BoundSql 对象而不是这个方法原生的对象。javassist能行么。我在网上摘了些代码运行不过去
[code="java"]
// 用于取得字节码类,必须在当前的classpath中,使用全称
CtClass ctClass = ClassPool.getDefault().get("org.apache.ibatis.mapping.MappedStatement");
// 需要修改的方法名称
String mname = "getBoundSql";
CtMethod mold = ctClass.getDeclaredMethod(mname);
// 修改原有的方法名称
String nname = mname + "$impl";
mold.setName(nname);
// 创建新的方法,复制原来的方法
CtMethod mnew = CtNewMethod.copy(mold, mname, ctClass, null);
// 主要的注入代码
StringBuffer body = new StringBuffer();
body.append("{return "+newBoundSql);
// 调用原有代码,类似于method();($$)表示所有的参数
//body.append(nname + "($$);\n");
//body.append("System.out.println(\"Call to method " + mname + " took \" +\n (System.currentTimeMillis()-start) + " + "\" ms.\");\n");
body.append("}");
// 替换新方法
mnew.setBody(body.toString());
// 增加新方法
ctClass.addMethod(mnew);
return (MappedStatement) ctClass.toClass().newInstance();
[/code]