????? 最近項(xiàng)目很變態(tài),硬是要把Domino的東西往J2EE上搬,說什么文檔型數(shù)據(jù)庫無法跨越系統(tǒng),我覺得如果照目前電信的系統(tǒng)結(jié)構(gòu)來說,就算把Domino上的所有東西,包括process都搬到J2EE上,也無法解決各個(gè)系統(tǒng)之間很好協(xié)作的問題,Portal和統(tǒng)一認(rèn)證已經(jīng)在某種程度上幫了大忙,如果實(shí)在很想各個(gè)應(yīng)用系統(tǒng)之間進(jìn)行數(shù)據(jù)交互,開發(fā)webservice接口就ok了,甚至在系統(tǒng)開始規(guī)劃的時(shí)候就不應(yīng)該出現(xiàn)Domino這種東西,現(xiàn)在想起關(guān)系型數(shù)據(jù)庫的好來了,未免累死了開發(fā)人員,所以我還是秉持我自己的原則:我們無限制的追求軟件程序的完美,并不是為了那幫傻逼客戶,而是為了讓我們之后的程序員能夠以更少的精力來更輕松的拿這份工資!????? 牢騷完畢來說說目前的J2EE做法。既然涉及到流程,那不免就那兩種,WFMC和BPEL,我們選擇BPEL,原因是IBM支持BPEL,不要問我兩種東西那種更優(yōu)秀,我會(huì)告訴你:你搞清楚了也沒意義,用戶只相信IBM。????? 既然用BPEL,IBM的Websphere Process Server首當(dāng)其沖,項(xiàng)目組買了幾百萬的軟件和服務(wù)就開始開發(fā)了,說實(shí)話,WPS真的是一個(gè)很好的SOA解決方案,但我個(gè)人認(rèn)為絕對(duì)不適合中國政府、國企的流程開發(fā),因?yàn)樗麩o法很好的解決人工節(jié)點(diǎn)的問題,哪怕是引入了human task,于是我們又自己封裝了一層小的流程引擎,當(dāng)然我所要說的重點(diǎn)不是這個(gè),而是我們?cè)趙ps中所需要的JCA方式綁定的組件的實(shí)現(xiàn)方式:EJB+Spring+Hibernate,做好的EJB包可以以EJB Bind的Java component形式打入wps的assembly里,在bpel process中reference進(jìn)來就可以了。下面我們主要說說EJB的實(shí)現(xiàn)。????? 由于wps有個(gè)特點(diǎn)就是在流程實(shí)例結(jié)束后刪除其自帶數(shù)據(jù)庫中的所有實(shí)例數(shù)據(jù),所以我們必須在流程的最后一部將數(shù)據(jù)記錄在我們自己的業(yè)務(wù)庫中來,我們開發(fā)的EJB就實(shí)現(xiàn)了這個(gè)功能。首先是業(yè)務(wù)邏輯,業(yè)務(wù)邏輯分成三個(gè)包,ejb、face、pojo,其中ejb是組件的本地接口,face是組件的功能性接口,pojo是具體實(shí)現(xiàn)類。??????具體邏輯代碼不貼了,貼一個(gè)我寫的例子:??????face中的功能接口:
Powered by: BlogJava Copyright © 江上一葉舟