ref:
http://thought-bytes.blogspot.com/2007/03/how-to-load-balance-tomcat-55-with.html
1. install the following software
jre 1.5 or 1.6, tomcat 5525, eclipse, axis2
and in eclipse preferences set tomcat to web server, set jre env and set axis2's runtime
2. create a java project and add axis2 runtime library to its build library
test ws client sample code:
public class TestSms
{
private static EndpointReference targetEPR = new EndpointReference(
"http://cdl:8080/axis2/services/Version");
public static OMElement getGetLeftElement(){
OMFactory fac=OMAbstractFactory.getOMFactory();
OMNamespace omNs=fac.createOMNamespace("此處填寫WS的命名空間","hw");
OMElement method=fac.createOMElement("WS 方法名",omNs);
OMElement value = fac.createOMElement("參數一", omNs);
value.addChild(fac.createOMText(value, "值一"));
method.addChild(value);
value = fac.createOMElement("參數二", omNs);
value.addChild(fac.createOMText(value, "值2"));
method.addChild(value);
return method;
}
public static void main(String[] args){
try{
Options options=new Options();
options.setTo(targetEPR);
options.setAction("命名空間/WS 方法名");
ServiceClient sender=new ServiceClient();
sender.setOptions(options);
OMElement sayHello=TestSms.getGetLeftElement();
//WSDLConstants.
OMElement result=sender.sendReceive(sayHello);
OMElement elem = result.getFirstElement();
System.out.println(elem.getText());
//System.out.println(result);
}
catch(Exception axisFault){
axisFault.printStackTrace();
}
}
}
Internet Explorer 4.x 及更高版本
最后不要忘了在這里測試一下是否安裝成功: http://www.java.com/zh_CN/download/help/testvm.xml
明天就是2005年最后一天了, 本想休一天假, 只是最近手頭上的項目跟別的公司有關, 脫不了身, 煩燥呀, 準LP又在罵了, 要生存, 沒辦法。
去年底搞了個今年十大目標,看了一下,沒幾個完成了,估計只有30-40%完成了。
整天都在忙,不管是公司的事還是自己的研究,這一年就沒有幾天晚上是12點之前睡的,在上一個公司經常是晚上11點回去睡覺,現在這家公司是回去之后繼續搞,所有的業余愛好都沒有了,買了個DC,也沒怎么用,什么都沒有心情,事情總是在那里等著,視力又下降了,身體感覺不如從前了。記憶力也下降了,前一陣子的事都不記得了,只知道這兩天做了些啥。
雖然又長了一歲,其它到是沒什么長進:
最近要在一個項目中使用java, 本來是用.net開發的, 可是驗收時用戶要求用java平臺,只好進行移植工作了. 一直使用的是.net開發, JAVA只是關注, 沒有深入研究, 等實際應用時才發現自己水平有限, 問題一堆.
把最近碰上的問題做些整理:
使用JAVA平臺的問題:
1. 開發工具太多, 什么Eclipse, jbuilder等,各有不同, 讓人熟悉就花時間了, 本為以為對JB比較熟悉,又有2006版本了, 就用它吧, 可是才兩天, 就發現自己的代碼文件中的中文變為亂碼了, 當然網上有一堆解決方案, 只是心里不爽, 直接不用了, 改為eclipse了, 操作界面不是很熟悉, 與VS.NET IDE還是有不少區別, 只是用多了自然就熟悉了,
又從網上當了一堆插件, 什么tomcat, xml編輯器, 沒有用myeclipse, 雖然支持JSP,以前用過一下, 也不太好用, 其它的就沒找到什么好東西了, 時間也不允許, 至少現在可以調度JAVA代碼了, JSP的調試再說吧.
2. 開始整的時候,發現自己在WEB開發方面熟悉的是VS的ASPX事件模型, 反而不知道如何處理JSP了, 只好使用以前ASP的模式, 使用form提交, 感覺真是太落伍了, 雖然現在有許多AJAX之類的東西, 也支持客戶端事件模型, 實在沒時間研究這些東西了. 先做出來再說.
數據庫連接類使用了以前jive中的幾個類, 支持在xml中配置連接等, 再自己寫了一個類, 從XML中讀取SQL語句, 差不多能用.
3。在網上搜索了一把,未找到在eclipse中對web service支持比較好的plugin,發現版本都比較低,似乎久未更新了,JB下到是有不錯的設計和編譯界面,只是JB其它太爛。
字符集問題:
使用java首先就要碰上一個中文字符的顯示和處理問題, 這些問題總是很煩, 要對request進行編碼才能解決.
既然使用非MS平臺, 數據庫可能就不會用到mssql server了, 使用mysql, 發現要移植以前的數據還是比較容易, 但mysql的驅動實在不好弄, 剛開始使用純JDBC的驅動, 結果發現在中文字符的處理上始終有問題, 只好
網上查原因, 發現jdbc驅動的版本太低, 在判斷中文字符上有問題, 升級驅動程序, 可以插入和顯示了, 但SQL中是中文, 可是進了數據庫就是亂碼, 試了N遍也不行, 只好改為jdbc-odbc.
但接下來在執行batch sql時又報錯了, 說mysql odbc driver 的SQL語法錯, 檢查了半天, SQL也能在mysql中執行的, 就是不能通過JAVA提交執行. 用的是mysql 5.0.X, 支持unicode 的編碼建表. 最后只能采用一個折衷的辦法,自己寫一個批量執行SQL的類,采用“;”分隔多個SQL,在調用時仍然一行一行的執行,郁悶。
最終的字符集解決辦法:
頁面上要設置字符集的輸出格式,如GBK或GB2312,另外,如果使用統一的包含文件定義輸出字符集,還是不行,必須在每個頁面中單獨定義,也可能是我的INCLUDE方式不對;
數據庫連接字符串中也要設置編碼;
在傳遞數據到DB的SQL還要對中文進行編碼;
String key = new String(request.getParameter("txtKey").getBytes("ISO8859_1"));
最后還有一個問題是,如果TOMCAT編譯JSP文件生成的JAVA文件有亂碼,那么在訪問的時候頁面上總是要報錯,什么"delete tokens"之類的,此時要刪除掉tomcat\work目錄下的中間編譯代碼才行;
控件及常用庫
WEB控件, 網上有一堆各種各樣的lib和控件, 但這些東西太浪費時間, 光是上網找就比較花時間了, 下回來試用也有各種各樣的問題,
每個控件有自己的特色, 而且每個總是滿足了這個,滿足不了那個需求, 要都滿足, 還是要收費的才行, 畢竟天下沒有多少免費的午餐;
主要有幾個:
1。數據顯示表格控件,應該能支持排序,有緩存機制,能分頁,能設置格式,支持ResultSet或ArrayList之類的,還要有導出excel等功能;最好要能簡單使用。
2。圖表控件,最有名的當然是cewolf/jfreechart,只是要使用它自己定義的DatasetProducer,不能直接使用ResultSet,也是個麻煩事,不過的確是很不錯的控件了。
小結
1。經過這次移植,發現JAVA還是有許多很牛的地方,采用hashmap來緩存數據,效率的確很不錯,只是用得太多,缺乏管理機制,有點混亂了,下一階段再重構一下,形成一個管理框架最好;
2。eclipse開發的確很不錯,與vs ide差別是比較大,只是使用習慣了之后發現其功能強大,而且可以找些plugin來擴展功能,估計我只是看到了點皮毛而已。
3。在JAVA下開發,使用Javascript太多,還沒找到更好解決辦法,水平有限;
4。與另一個人一起開發,大家的編程風格和代碼不夠規范,使用了一些重復的類和方法,這在后期維護是個工作,時間太緊,項目總是這樣,就沒得多少提高了;
個人水平實在有限,上面只是一面之詞,項目月底才結束,有什么變更再補充。
An early look at JUnit 4Upcoming release promises evolution in testing |
難度級別: 中 Elliotte Harold (elharo@metalab.unc.edu),
Adjunct Professor, Polytechnic University 2005-9-15 (譯) 原文:http://www-128.ibm.com/developerworks/java/library/j-junit4.html JUnit 是JAVA語言事實上的標準測試庫。JUnit 4是三年以來最具里程碑意義的一次發布。它的新特性主要是針對JAVA5中的標記(annotation)來簡化測試,而不是利用子類、反射或命名機制。本文將講述如何使用JUnit 4,當前前提是你最好具有JUnit的使用經驗. JUnit, 由Kent Beck?和 Erich Gamma開發,幾乎是JAVA開發最重要的第三方工具。正如Martin Fowler 所說,“在軟件開發領域,從來就沒有如此少的代碼起到了如此重要的作用“。由于JUnit,JAVA代碼變得更健壯,更可靠,BUG也比以前更少。由于JUnit (由Smalltalk's的SUnit得來) 的出現,隨后產生了許多xUnit的測試工具,如nUnit (.NET), pyUnit (Python), CppUnit (C++), dUnit (Delphi) 和其它不同平臺及語言的測試相關的工具。 雖然JUnit也只是一個工具,但其產生的思想和技術卻較其架構更意義重大。單元測試,測試先行的編程方式,測試驅動的開發方式,并非必須由JUNIT實現,也不一定要用SWing實現GUI界面。JUNIT最近的一次更新是在三年前,但它比其它大多數有BUG的框架都要健壯,更重要的是,JAVA一直在改進。現在JAVA支持泛型,枚舉,可變長度參數,以及標記語言(開創了開發可重用框架的新局面)。 JUnit's的停滯不前使得那些想要變革的開發人員換其它測試工具.挑戰者有Bill Venners的Artima SuiteRunner和Cedric Beust的TestNG.這些工具庫雖然有值得推薦的功能,但沒有任何一款的地位能與JUNIT相比,沒有任何一款工具被其它業界產品如Ant, Maven, Eclipse廣泛支持.因此Beck 和Gamma雙開始利用JAVA5的新特性來開發新版的JUNIT,目的是利用JAVA5中的標記特性使得單元測試開發更容易。Beck說:“JUNIT4的主要目的是通過簡化JUNIT的使用鼓勵更多的開發人員寫更多的測試”。雖然會與以前的版本兼容,但JUNIT4與從JUNIT1.0就開始的版本相比會有一個非常大的變化. 注意: 修改基本框架是一把雙刃劍,雖然JUNIT4的目的是清晰的,但細節仍有許多不同,因此本文只是一個簡單的介紹,并不是最終文檔. 以前所有版本的JUNIT都使用命名機制和反射來定位測試,下面的代碼測試1+1= 2:
而在JUNIT 4中,測試方法由@Test 標記說明,如下:
使用標記的好處是你不用將所有測試方法命名為
下面的代碼也同樣正確:
這種命名機制最大的優點是更適合你的待測試類或方法名稱,例如,你可以使用ListTEst.contains()測試
你也可以使用JDK5中的新特性(static import)使得跟以前版本一樣簡單:
這種方法測試受保護的方法非常容易,因為你可以在測試類中繼承有受保護方法的類.
JUnit 3 中test runners 會在每個測試之前自動調用
在JUnit 4中,你仍然可以在每個測試前初始化變量和配置環境,,然而,這些操作可以不用在Setup()中完成,你可以在初始化方法前面添加@Beforer 來表示,如下:
你也可以有多個方法標記有@Before,所有方法都會在每個測試之前執行:
清除環境與JUNIT3 差不多,在JUNIT3中使用
在JUnit 4中,你還可以使用@After標記來說明:
與 最后,你不需要在父類中明確調用這些初始化或清除方法.test runner會自動調用這些標記的方法.子類中的@Before方法在父類的@Before方法之后執行(這與構造函數的執行順序一樣),而@After方法剛好相反,子類中的@After方法先執行.然而,多個@Before和@After方法的執行順序就是未知的. 測試集范圍的初始化 JUnit 4中引入了一項JUNIT3沒有的新特性,類級別的setUp()和tearDown(),即在一個類的所有測試前執行初始化,并在所有測試完成后執行清除。 例如,一個測試類中的每個測試都要用到一個數據庫連接或網絡連接,或其它很耗資源初始化或釋放的資源,用不著在每個測試方法前后進行操作,而只需要在測試類開始前后執行即可。下面的示例是使用第三方的庫進行錯誤,在執行所有測試前將錯誤先重定向到非標準輸出,然后在所有測試結束后再輸出到需要的地方,這樣就不會影響到測試過程中產生的其它信息。
上面的操作沒有必須在每個測試前后執行。然而要注意的是,這種方法可能影響測試間的結果,如果一個測試改變了初始化的對象,而這個對象可能是其它測試的輸入,那么測試的結果可能不正確,這種方法將依賴測試的順序并可能引入BUG。當優化測試性能,并且當你改進了配置和基準測試后而仍然很慢時,如數據庫連接或網絡問題,你才需要考慮使用這種方法。只有這樣,你才能每天執行多次測試。
異常測試是JUNIT4中的最大的改進,以前異常測試是通過try catch實現,當拋出異常時,在try的最后添加一條fail()語句實現.如下:
這種方法不僅難看,而且造成無論成功或失敗,代碼覆蓋工具都不能執行某些代碼.而在JUnit 4中,你可以在要拋出異常的代碼中添加標記來聲明一個異常是期望的:
如果沒有異常拋出,上面的測試則會失敗,如果你想知道異常的詳細信息或其它情況,你還是要使用try catch才行
需要忽略的測試
也許你有些測試需要很長時間才能執行完成,并非是這個測試應該跑得快,而是它做的很復雜和很慢的工作造成的.如訪問遠程網絡錯誤,需要很久才能有反饋.如果你不想讓這種測試破壞你整個測試過程,你可能想跳過這個測試.當然也有可能某個測試超出控制范圍而失敗.如W3C
XInclude測試集中自動識別一些JAVA不支持的Unicode代碼.為了防止這些測試總是通不過,可以使用標記
test runner不會執行這些測試,但會說明這些測試被跳過了。在命令行測試界面中,字母“I”會表示測試跳過,或“E”表示測試失敗,而不是用點”."表示成功.
要注意的是,假設這些測試由于某種理由放在最開始,如果你以后一直忽略這些測試,那些需要被測試的代碼可能有問題而不會被檢測到。因此忽略測試只是一個臨時解決方法,并不是一個解決任何問題的真正辦法。
時間測試 性能測試是單元測試中最頭疼的問題,JUnit 4也未完全解決此問題, 你可以在JUNIT4的測試方法中添加一個時間參數。如果測試時間超過參數,則測試失敗。如下,如果測試時間超過0.5秒,則此測試失敗:
除基準性能測試外,時間測試在網絡測試方面也很有用.如果一個遠端的主機或數據當掉或太慢,你可以跳過此測試而不用阻塞在這里,好的測試集可以在作了一些改動后很快的一遍一遍的執行,可能一天數十次.設置一個超時讓測試更快的執行,下面的示例中如果分析http://www.ibiblio.org/xml 的時間超過2秒,則測試失敗.
JUnit 4 增加了兩上斷文方法用于比較數組:
這兩個方法采用最直接方法比較,如果數組長度相同,且每個對應的元素相同,則比較成功,否則不成功.參數為空的情況也作了考慮.
需要補充的地方 JUnit 4是一個非常基本的框架,還不是以前版本的升級。JUNIT3的開發人員會發現有些功能沒有。
沒有GUI測試界面的確不方便,但其它改變簡化了JUNIT的使用,從當前JUNIT的操作手冊和FAQ的數量就知道,而JUNIT4的文檔將不會需要這么多。
現在JUnit 4還沒有發布編譯版本,如果想體驗版本的樂趣,則需要從CVS中獲取源代碼。分支標簽是"Version4" (see Resources ).要注意的是大部分文檔是根據JUNIT3編寫的,還未同步更新。需要Java 5才能編譯JUnit 4,因為大量使用了標記,泛型其其它JDK5中的新特性。
執行測試的命令行方式與JUNIT3有點區別,你現在要使用
Beck 和Gamma在努力保持后向和前向兼容性。JUnit 4可以直接運行根據JUNIT3編寫的測試類,而不用任何修改,直接將各測試類的全名傳遞給test runner即可.test runner會根據不同的測試類調用不同的測試框架版本.
后向兼容性有點麻煩,即在JUNIT3中執行根據JUNIT4寫的測試類,之所以要這樣是因為在一個集成環境如Ecplise中,不需要升級到JUNIT4也可以測試JUNIT4的測試類,從而避免工具IDE的升級。為了讓JUNIT4的測試類在JUNI3中能執行,你需要一個適配類
而JAVA方面,JUNIT4一點兼容性都沒有,因為完全依賴于JDK5的新特性,因此不可能在JAVA1.4上面執行JUNIT4。
還有... JUnit 4遠未結束,還有許多需要補充,如文檔,現在不推薦將以前的測試類升級到JUNIT4。當然JUNIT4的開發速度很快,其計劃也很快會實現,JAVA1.4的開發人員仍然可以使用JUNIT3.8,而使用JAVA5的人員可以考慮是否采用JUNIT4了,因為在特性上更適合。
下載測試版本
|