本文實例講述了java動態代理實現方法。分享給大家供大家參考,具體如下:
靜態代理了解的差不多了,但是對于動態代理理解的還不是很通透,這里先把一些常用的動態代理實現方法記錄下來,日后時常看看爭取早日融會貫通。
1、jdk實現動態代理
主要使用了proxy.newproxyinstance()方法,該方法的官方解釋為:返回一個指定接口的代理類實例,該接口可以將方法調用指派到指定的調用處理程序。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
|
public interface isomeservice { string dofirst(); void dosecond(); string dothird(); } //目標類:代理類要增強的類 public class someserviceimpl implements isomeservice { @override public string dofirst() { return "aaabbb" ; } @override public void dosecond() { system.out.println( "someserviceimpl:執行dosecond()" ); } @override public string dothird() { return "aaa" ; } } public class mytest { public static void main(string[] args) { isomeservice target = new someserviceimpl(); isomeservice someservice = (isomeservice) proxy.newproxyinstance( target.getclass().getclassloader(), target.getclass().getinterfaces(), new invocationhandler() { // proxy:代理對象 // method:目標方法 // args:目標方法的參數列表 @override public object invoke(object proxy, method method, object[] args) throws throwable { object result = method.invoke(target, args); if (result!= null ) { result=((string)result).touppercase(); } return result; } }); system.out.println(someservice.dofirst()); someservice.dosecond(); system.out.println(someservice.dothird()); } } |
2、cglib實現動態代理(沒接口)
使用jdk的proxy實現動態代理,要求目標類與代理類實現相同的接口,若目標類不存在接口,則無法使用該方式實現。
對于沒有接口的類,要為其創建動態代理,就要使用cglib來實現。cglib動態代理的生成原理是生成目標類的子類,而子類是增強過的,這個子類對象就是代理對象。使用cglib生成代理類,要求目標類必須能被繼承,因此不能是final類。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
|
//目標類:代理類要增強的類 public class someservice { public string dofirst() { system.out.println( "someserviceimpl:執行dofirst()" ); return "aaabbb" ; } public void dosecond() { system.out.println( "someserviceimpl:執行dosecond()" ); } } //注意:使用cglib動態代理,要求目標類不能是final的 //cglib動態代理的增強原理是:子類增強父類,所以目標類必須能被繼承 public class cglibfactory implements methodinterceptor { private someservice target; public cglibfactory() { } public cglibfactory(someservice target) { this .target = target; } public someservice mycglibcreator() { enhancer enhancer = new enhancer(); //指定父類,即目標類。因為cglib動態代理增強的原理是:子類增強父類 enhancer.setsuperclass(someservice. class ); //設置回調接口對象 enhancer.setcallback( this ); //create()方法用于創建cglib動態代理對象 return (someservice)enhancer.create(); } //回調函數的執行條件:代理對象執行目標方法時會觸發該方法 @override public object intercept(object obj, method method, object[] args, methodproxy proxy) throws throwable { object invoke = method.invoke(target, args); if (invoke!= null ) { invoke=((string)invoke).touppercase(); } return invoke; } } public class mytest { public static void main(string[] args) { someservice target = new someservice(); someservice proxy = new cglibfactory(target).mycglibcreator(); proxy.dofirst(); } } |
3、cglib實現動態代理(有接口)
在有接口的情況下利用cglib實現動態代理跟沒有接口的情況下利用cglib實現動態代理,其實差不多。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
|
public interface isomeservice { string dofirst(); void dosecond(); string dothird(); } //目標類:代理類要增強的類 public class someservice implements isomeservice { public string dofirst() { return "aaabbb" ; } public void dosecond() { system.out.println( "someserviceimpl:執行dosecond()" ); } @override public string dothird() { return "third" ; } } //注意:使用cglib動態代理,要求目標類不能是final的 //cglib動態代理的增強原理是:子類增強父類,所以目標類必須能被繼承 public class cglibfactory implements methodinterceptor { private isomeservice target; public cglibfactory() { } public cglibfactory(isomeservice target) { this .target = target; } public isomeservice mycglibcreator() { enhancer enhancer = new enhancer(); //指定父類,即目標類。因為cglib動態代理增強的原理是:子類增強父類 enhancer.setsuperclass(isomeservice. class ); //設置回調接口對象 enhancer.setcallback( this ); //create()方法用于創建cglib動態代理對象 return (isomeservice)enhancer.create(); } //回調函數的執行條件:代理對象執行目標方法時會觸發該方法 @override public object intercept(object obj, method method, object[] args, methodproxy proxy) throws throwable { object invoke = method.invoke(target, args); if (invoke!= null ) { invoke=((string)invoke).touppercase(); } return invoke; } } public class mytest { public static void main(string[] args) { isomeservice target = new someservice(); isomeservice proxy = new cglibfactory(target).mycglibcreator(); system.out.println(proxy.dofirst()); proxy.dosecond(); system.out.println(proxy.dothird()); } } |
希望本文所述對大家java程序設計有所幫助。
原文鏈接:https://blog.csdn.net/xiaouncle/article/details/80413350