亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

EJB調用的原理分析

2019-11-18 12:35:42
字體:
來源:轉載
供稿:網友

  一個遠程對象至少要包括4個class文件:遠程對象;遠程對象的接口;實現遠程接口的對象的stub;對象的skeleton這4個class文件。
  
  在EJB中則至少要包括10個class:
  Bean類,特定App Server的Bean實現類
  Bean的remote接口,特定App Server的remote接口實現類,特定App Server的remote接口的實現類的stub類和skeleton類
  Bean的home接口,特定App Server的home接口實現類,特定App Server的home接口的實現類的stub類和skeleton類
  
  和RMI不同的是,EJB中這10個class真正需要用戶編寫的只有3個,分別是Bean類和它的remote接口,home接口,至于其它的7個class到底是怎么生成,被打包在什么地方,或者是否需要更多的類文件,會根據不同的App Server表現出比較大的差異,不能一概而論。
  
  拿我最熟悉的Weblogic的來說吧,Weblogic的Bean實現類,以及兩個接口的Weblogic的實現類是在ejbc的時候被打包到EJB的jar包里面的,這3個class文件可以看到。而home接口和remote接口的Weblogic的實現類的stub類和skeleton類是在EJB被部署到Weblogic的時候,由Weblogic動態生成stub類和Skeleton類的字節碼,因此看不到這4個類文件。
  
  對于一次客戶端遠程調用EJB,要經過兩個遠程對象的多次RMI循環。首先是通過JNDI查找Home接口,獲得Home接口的實現類,這個過程其實相當復雜,首先是找到Home接口的Weblogic實現類,然后創建一個Home接口的Weblogic實現類的stub類的對象實例,將它序列化傳送給客戶端(注重stub類的實例是在第1次RMI循環中,由服務器動態發送給客戶端的,因此不需要客戶端保存Home接口的Weblogic實現類的stub類),最后客戶端獲得該stub類的對象實例(普通的RMI需要在客戶端保存stub類,而EJB不需要,因為服務器會把stub類的對象實例發送給客戶端)。
  
  客戶端拿到服務器給它的Home接口的Weblogic實現類的stub類對象實例以后,調用stub類的create方法,(在代碼上就是home.create(),但是后臺要做很多事情),于是經過第2次RMI循環,在服務器端,Home接口的Weblogic實現類的skeleton類收到stub類的調用信息后,由它再去調用Home接口的Weblogic實現類的create方法。
  
  在服務端,Home接口的Weblogic實現類的create方法再去調用Bean類的Weblogic實現類的ejbCreate方法,在服務端創建或者分配一個EJB實例,然后將這個EJB實例的遠程接口的Weblogic實現類的stub類對象實例序列化發送給客戶端。
  
  客戶端收到remote接口的Weblogic實現類的stub類的對象實例,對該對象實例的方法調用(在客戶端代碼中實際上就是對remote接口的調用),將傳送給服務器端remote接口的Weblogic實現類的skeleton類對象,而skeleton類對象再調用相應的remote接口的Weblogic實現類,然后remote接口的Weblogic實現類再去調用Bean類的Weblogic實現類,如此就完成一次EJB對象的遠程調用。
  
  看了一遍帖子,感覺還是沒有說太清楚,既然寫了帖子,就想徹底把它說清楚。
  
  先拿普通RMI來說,有4個class,分別是遠程對象,對象的接口,對象的stub類和skeleton類。而對象本身和對象的stub類同時都實現了接口類。而我們在客戶端代碼調用遠程對象的時候,雖然在代碼中操縱接口,實質上是在操縱stub類,例如:
  接口類:Hello
  遠程對象:Hello_Server
  stub類:Hello_Stub
  skeleton類:Hello_Skeleton
  
  客戶端代碼要這樣寫:
  Hello h = new Hello_Stub();
  h.getString();
  
  我們不會這些寫:
  Hello_Stub h = new Hello_Stub();
  h.getString();
  
  因為使用接口適用性更廣,就算更換了接口實現類,也不需要更改代碼。因此客戶端需要Hello.class和Hello_Stub.class這兩個文件。但是對于EJB來說,就不需要Hello_Stub.class,因為服務器會發送給它,但是Hello.class文件客戶端是省不了的,必須有。表面上我們的客戶端代碼在操縱Hello,但別忘記了Hello只是一個接口,抽象的,實質上是在操縱Hello_Stub。
  
  拿Weblogic上的EJB舉例子,10個class分別是:
  Bean類:HelloBean (用戶編寫)
  Bean類的Weblogic實現類:HelloBean_Impl (EJBC生成)
  
  Home接口:HelloHome (用戶編寫)
  Home接口的Weblogic實現類 HelloBean_HomeImpl(EJBC生成)
  Home接口的Weblogic實現類的stub類 HelloBean_HomeImpl_WLStub(部署的時候動態生成字節碼)
  Home接口的Weblogic實現類的skeleton類 HelloBean_HomeImpl_WLSkeleton(部署的時候動態生成字節碼)
  
  Remote接口: Hello (用戶編寫)
  Remote接口的Weblogic實現類 HelloBean_EOImpl(EJBC生成)
  Remote接口的Weblogic實現類的stub類 HelloBean_EOImpl_WLStub(部署的時候動態生成字節碼)
  Remote接口的Weblogic實現類的skeleton類 HelloBean_EOImpl_WLSkeleton(部署的時候動態生成字節碼)
  
  客戶端只需要Hello.class和HelloHome.class這兩個文件。
  
  HelloHome home = (Home) PortableRemoteObject.narrow(ctx.lookup("Hello"), HelloHome.class);
  
  這一行代碼是從JNDI獲得Home接口,但是請記??!接口是抽象的,那么home這個對象到底是什么類的對象實例呢?很簡單,用toString()輸出看一下就明白了,下面一行是輸出結果:
  HelloBean_HomeImpl_WLStub@18c458
  這表明home這個通過從服務器的JNDI樹上查找獲得的對象實際上是HelloBean_HomeImpl_WLStub類的一個實例。
  接下來客戶端代碼:
  
  Hello h = home.create()
  
  同樣Hello只是一個抽象的接口,那么h對象是什么東西呢?打印一下:
  HelloBean_EOImpl_WLStub@8fa0d1
  原來是HelloBean_EOImpl_WLStub的一個對象實例。
  
  用這個例子來簡述一遍EJB調用過程:
  
  首先客戶端JNDI查詢,服務端JNDI樹上Hello這個名字實際上綁定的對象是HelloBean_HomeImpl_WLStub,所以服務端將創建HelloBean_HomeImpl_WLStub的一個對象實例,序列化返回給客戶端。
  
  于是客戶端得到home對象,表面上是得到HelloHome接口的實例,實際上是進行了一次遠程調用得到了HelloBean_HomeImpl_WLStub類的對象實例,別忘記了HelloBean_HomeImpl_WLStub也實現了HelloHome接口。
  
  然后home.create()實質上就是HelloBean_HomeImpl_WLStub.create(),該方法將發送信息給HelloBean_HomeImpl_WLSkeleton,而HelloBean_HomeImpl_WLSkeleton接受到信息后,再去調用HelloBean_HomeImpl的create方法,至此完成第1次完整的RMI循環。
  
  注重在這次RMI循環過程中,遠程對象是HelloBean_HomeImpl,遠程對象的接口是HelloHome,對象的stub是HelloBean_HomeImpl_WLStub,對象的skeleton是HelloBean_HomeImpl_WLSkeleton。
  
  然后HelloBean_HomeImpl再去調用HelloBean_Impl的ejbCreate方法,而HelloBean_Impl的ejbCreate方法將負責創建或者分配一個Bean實例,并且創建一個HelloBean_EOImpl_WLStub的對象實例。
  
  這一步比較有趣的是,在前一步RMI循環中,遠程對象HelloBean_HomeImpl在客戶端有一個代理類HelloBean_HomeImpl_WLStub,但在這一步,HelloBean_HomeImpl自己卻充當了HelloBean_Impl的代理類,只不過HelloBean_HomeImpl不在客戶端,而是在服務端,因此不進行RMI。
  
  然后HelloBean_EOImpl_WLStub的對象實例序列化返回給客戶端,這一步也很有趣,上次RMI過程,主角是HelloBean_HomeImpl和它的代理類HelloBean_HomeImpl_WLStub,但這這一次換成了HelloBean_EOImpl和它的代理類HelloBean_EOImpl_WLStub來玩了。
  
  Hello h = home.create();h.helloWorld();
  
  假設Hello接口有一個helloWorld遠程方法,那么表面上是在調用Hello接口的helloWorld方法,實際上是在調用HelloBean_EOImpl_WLStub的helloWorld方法。
  
  然后HelloBean_EOImpl_WLStub的helloWorld方法將發送信息給服務器上的HelloBean_EOImpl_WLSkeleton,而HelloBean_EOImpl_WLSkeleton收到信息以后,再去調用HelloBean_EOImpl的helloWorld方法。至此,完成第2次完整的RMI循環過程。
  
  在剛才HelloBean_EOImpl是作為遠程對象被調用的,它的代理類是HelloBean_EOImpl_WLStub,但現在HelloBean_EOImpl要作為HelloBean_Impl的代理類了?,F在HelloBean_EOImpl去調用HelloBean_Impl的helloWorld方法。注重!HelloBean_Impl繼續了HelloBean,而HelloBean中的helloWorld方法是我們親自編寫的代碼,現在終于調用到了我們編寫的代碼了!
  
  至此,一次EJB調用過程終于完成。在整個過程中,服務端主要要調用的類是HelloBean_Impl, HelloBean_HomeImpl,HelloBean_HomeImpl_WLSkeleton,HelloBean_EOImpl,HelloBean_EOImpl_WLSkeleton??蛻舳酥饕{用的類是HelloBean_HomeImpl_WLStub,HelloBean_EOImpl_WLStub,這兩個類在客戶端代碼中并不會直接出現,出現在代碼中的類是他們的接口HelloHome和Hello,因此客戶端需要這兩個接口文件,而Stub是服務器傳送給他們的。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
中文字幕日韩精品有码视频| 国产精品美腿一区在线看| 欧美怡红院视频一区二区三区| 国产精品视频26uuu| 97人人爽人人喊人人模波多| 91免费看视频.| 亚洲欧美综合精品久久成人| 国产精品69久久久久| 国产一区二区三区免费视频| 日韩在线视频中文字幕| 日韩视频在线观看免费| 在线成人中文字幕| 亚洲成av人片在线观看香蕉| 欧美精品免费看| 亚洲免费av网址| 国产精品免费久久久| 成人天堂噜噜噜| 国产精品免费久久久| 精品亚洲aⅴ在线观看| 国产亚洲精品91在线| 成人深夜直播免费观看| 夜色77av精品影院| 国产亚洲精品高潮| 久久久久www| 国产午夜精品麻豆| 黄色成人在线免费| 久久6免费高清热精品| 国产精品成人观看视频国产奇米| 欧美肥臀大乳一区二区免费视频| 国产精品久久久久久久久久久不卡| 欧美高清无遮挡| 欧美一区二区色| 国产欧美精品久久久| 午夜精品福利视频| 欧美一区二区视频97| 亚洲午夜久久久影院| 97在线视频国产| 91精品国产高清自在线| 国产精品视频一| 国产精品白嫩初高中害羞小美女| 一本色道久久综合狠狠躁篇的优点| 亚洲欧美国产精品专区久久| 欧美精品videossex88| 裸体女人亚洲精品一区| 亚洲国产精品成人va在线观看| 亚洲国内精品视频| 亚洲大胆人体在线| 亚洲精品久久7777777| 日本视频久久久| 精品国产999| 国模精品一区二区三区色天香| 日韩精品在线视频观看| 日韩成人在线视频网站| 91亚洲va在线va天堂va国| 日韩美女在线看| 国产精品久久久久久av福利软件| 欧美激情网站在线观看| 国产一区二区av| 亚洲一区二区三区四区视频| 国产精品久久久999| 日韩精品福利网站| 国产精品久久久久影院日本| 国产日韩欧美另类| 欧美另类99xxxxx| 国产精品男人的天堂| 亚洲字幕一区二区| 91精品在线播放| 欧美亚洲成人xxx| 日韩欧美aⅴ综合网站发布| 在线播放国产一区中文字幕剧情欧美| 91精品久久久久久久久久久久久| 日韩激情视频在线| 国产97在线观看| 色偷偷噜噜噜亚洲男人的天堂| 中日韩美女免费视频网址在线观看| 狠狠做深爱婷婷久久综合一区| 2019中文在线观看| 日韩在线免费视频观看| 欧美性20hd另类| 青青草99啪国产免费| 亚洲欧美国产精品久久久久久久| 亚洲黄色有码视频| 欧美黄色片视频| 国产精品白丝av嫩草影院| 国内精品久久久久久中文字幕| 亚洲国产天堂网精品网站| 精品国产福利在线| 在线观看国产成人av片| 欧美日韩精品在线视频| 亚洲国产精品yw在线观看| 亚洲成人xxx| 欧美激情视频网站| 亚洲天堂男人天堂女人天堂| 北条麻妃一区二区三区中文字幕| 成人美女免费网站视频| 国产91精品视频在线观看| 国产女人精品视频| 日韩欧美亚洲成人| 久久久国产视频| 国产欧美日韩精品丝袜高跟鞋| 色狠狠av一区二区三区香蕉蜜桃| 欧美激情va永久在线播放| 国产成人免费av电影| 日韩在线视频免费观看高清中文| 欧美中文字幕在线观看| 精品国产视频在线| 色播久久人人爽人人爽人人片视av| 国产精品你懂得| 日韩欧美福利视频| 欧美日韩激情网| 亚洲欧洲美洲在线综合| 日韩精品极品毛片系列视频| 91久久综合亚洲鲁鲁五月天| 欧美性受xxxx白人性爽| 91免费人成网站在线观看18| 久久香蕉国产线看观看网| 国产精品一区二区女厕厕| 日韩大胆人体377p| 亚洲伊人久久大香线蕉av| 成人网中文字幕| 亚洲18私人小影院| 26uuu亚洲伊人春色| xxav国产精品美女主播| 欧美香蕉大胸在线视频观看| 久久久999国产| 欧美日韩在线视频首页| 国产精品xxx视频| 国产欧美日韩91| 亚洲一区二区三区在线免费观看| 欧美色视频日本高清在线观看| 日韩a**站在线观看| 日韩欧美在线视频观看| 日韩av色在线| 97香蕉超级碰碰久久免费软件| 91精品国产综合久久香蕉最新版| 91亚洲一区精品| 不卡av在线网站| 欧美一区二区大胆人体摄影专业网站| 久热精品视频在线免费观看| 国产精品xxxxx| 日韩中文字幕在线视频播放| 亚洲欧洲日产国码av系列天堂| 国产精品精品视频| 国产精品一区专区欧美日韩| 日韩欧美在线观看| 亚洲一区美女视频在线观看免费| 91久久国产综合久久91精品网站| 国产精品视频成人| 亚洲一区二区免费| 国产精品欧美日韩一区二区| 中文字幕精品在线| 亚洲免费伊人电影在线观看av| 毛片精品免费在线观看| 国产一区二区三区网站| 久久躁日日躁aaaaxxxx| 91久久久在线| 欧美在线一区二区视频| 91av国产在线| 精品视频在线导航| 国产97人人超碰caoprom| 亚洲欧美日本伦理| 亚洲无限乱码一二三四麻| 中文.日本.精品| 久久天天躁狠狠躁夜夜躁|