代理机制:根据反射,执行代理的方法
package com.hdsx.demo;
import java.lang.reflect.Proxy;
public class Test {
public static void main(String[] args) {
UserManager um = new UserManagerImpl();
LogHandler lh = new LogHandler(um);
UserManager userManager = (UserManager) Proxy
.newProxyInstance(um.getClass().getClassLoader(), um.getClass()
.getInterfaces(), lh);
// UserManager userManager=new UserManagerImpl();
userManager.delete(5);
userManager.save("lkl", "123");
System.out.println(userManager.select(5));
}
}
public class LogHandler implements InvocationHandler {
Object targetObject;
public LogHandler(Object targetObject) {
this.targetObject = targetObject;
}
public Object invoke(Object proxy, Method method, Object[] args)
throws Throwable { // if(method.getName().startsWith("delete"))
log();
Object ret = method.invoke(this.targetObject, args);
return ret;
}
public void log() {
System.out.println("------------write log into logfile--------------");
}
}
package com.hdsx.demo;
public interface UserManager {
public void save(String name,String pwd);
public void update(String name,String pwd,String repwd);
public void delete(int id);
public String select(int id);
}
package com.hdsx.demo;
public class UserManagerImpl implements UserManager {
public void delete(int id) {
System.out.println("------------UserManagerImpl.delete(id)------------");}
public void save(String name, String pwd) {
System.out.println("------------UserManagerImpl.save(name, pwd)------------");}
public String select(int id) {
System.out.println("------------UserManagerImpl.select(id)------------");
return null;}
public void update(String name, String pwd, String repwd) {
System.out.println("-------UserManagerImpl.update(name, pwd,repwd)-----");}
}