qqjianyue代碼工

          砌java代碼
          posts - 62, comments - 9, trackbacks - 0, articles - 10
            BlogJava :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

          2010年1月20日

          1. Change to aliyun repository

          2. Chinese input method
          sudo apt-get install ibus-pinyin
          #remmeber to logout and re-logon to change system 'Region&Language' setting

          3. Shadowsocks and genpac
          sudo apt install -y shadowsocks-libev
          #sudo vi /etc/shadowsocks-libev/shadowsock.json
          {
              
          "server":"x.x.x.x",
              
          "server_port":xx,
              
          "local_port":1080,
              
          "password":"xxxxx",
              
          "timeout":60,
              
          "method":"aes-256-cfb"
          }

          nohup ss-local -c /etc/shadowsocks-libev/shadowsock.json >/dev/null 2>&1 &

          sudo apt install phython-pip
          sudo -H
          pip install genpac


          如果pip error "TypeError: unsupported operand type(s) for -=: 'Retry' and 'int'"
          sudo python -m pip install --upgrade --force pip

          mkdir pac
          cd pac
          touch user-rules.txt
          genpac --pac-proxy "SOCKS5 127.0.0.1:1080" --gfwlist-proxy="SOCKS5 127.0.0.1:1080" --output="autoproxy.pac" --gfwlist-url="https://raw.githubusercontent.com/gfwlist/gfwlist/master/gfwlist.txt" --user-rule-from="user-rules.txt"

          配置系統(tǒng)自動(dòng)代理為:
          /home/xxx/pac/autoproxy.pac

          4. JDK8
          https://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html
          download and setup environment variable manually


          5.gcloud
          http://ubuntuhandbook.org/index.php/2014/10/google-cloud-sdk-made-into-canonical-partners-repository/

          posted @ 2018-11-03 08:39 Qzi 閱讀(204) | 評(píng)論 (0)編輯 收藏

          官方說明:http://source.android.com/source/initializing.html
          環(huán)境:
          Ubuntu 12.04 64bit
          JDK6(installation: http://www.gaggl.com/2012/04/installing-java6-jdk-on-ubuntu-12-04/)

          $ make -v
          GNU Make 3.81
          Copyright (C) 2006  Free Software Foundation, Inc.
          This is free software; see the source for copying conditions.
          There is NO warranty; not even for MERCHANTABILITY or FITNESS FOR A
          PARTICULAR PURPOSE.
          This program built for x86_64-pc-linux-gnu
          $ python -V
          Python 2.7.3
          android 當(dāng)前 mainfest version: 4.2


          按照官方說明從下載到運(yùn)行emulator,沒有nexus,所以沒做實(shí)際機(jī)器燒錄。步驟請(qǐng)根據(jù)官方說明做,以下只列出過程遇到的問題:
          1.repo sync
          經(jīng)常出現(xiàn)斷線,網(wǎng)上有很多參考辦法,我是每次忽略這些錯(cuò)誤,直到運(yùn)行完畢退出,我再重新運(yùn)行:
          repo sync -f
          知道所有代碼下載完畢(4.2的有16G)
          2.每次跑emulator都要cd到代碼目錄先進(jìn)行環(huán)境初始化
          source build/envsetup.sh
          lunch full-eng
          3.emulator出錯(cuò)
          $ emulator
          emulator: WARNING: system partition size adjusted to match image file (229 MB > 200 MB)
          Segmentation fault (core dumped)
          改成用emulator-arm -partition-size 1024
          full long command reference:
          http://stackoverflow.com/questions/9022750/running-emulator-after-building-android-from-source

          posted @ 2013-04-20 10:57 Qzi 閱讀(306) | 評(píng)論 (0)編輯 收藏

          Spring 聲明式事務(wù)讓我們從復(fù)雜的事務(wù)處理中得到解脫。使得我們?cè)僖矡o需要去處理獲得連接、關(guān)閉連接、事務(wù)提交和回滾等這些操作。再也無需要我們?cè)谂c事務(wù)相關(guān)的方法中處理大量的 try catch  finally 代碼。 我們?cè)谑褂?/span> Spring 聲明式事務(wù)時(shí),有一個(gè)非常重要的概念就是事務(wù)屬性。事務(wù)屬性通常由事務(wù)的傳播行為,事務(wù)的隔離級(jí)別,事務(wù)的超時(shí)值和事務(wù)只讀標(biāo)志組成。我們?cè)谶M(jìn)行事務(wù)劃分時(shí),需要進(jìn)行事務(wù)定義,也就是配置事務(wù)的屬性。

           

          Spring  TransactionDefinition 接口中定義這些屬性 , 以供 PlatfromTransactionManager 使用 , PlatfromTransactionManager  spring 事務(wù)管理的核心接口。

           

          l         getTimeout() 方法,它返回事務(wù)必須在多少秒內(nèi)完成。

          l         isReadOnly() , 事務(wù)是否只讀,事務(wù)管理器能夠根據(jù)這個(gè)返回值進(jìn)行優(yōu)化,確保事務(wù)是只讀的。

          l         getIsolationLevel() 方法返回事務(wù)的隔離級(jí)別,事務(wù)管理器根據(jù)它來控制另外一個(gè)事務(wù)可以看到本事務(wù)內(nèi)的哪些數(shù)據(jù)。

           

           TransactionDefinition 接口中定義了五個(gè)不同的事務(wù)隔離級(jí)別:

           

          l         ISOLATION_DEFAULT 這是一個(gè) PlatfromTransactionManager 默認(rèn)的隔離級(jí)別,使用數(shù)據(jù)庫默認(rèn)的事務(wù)隔離級(jí)別 . 另外四個(gè)與 JDBC 的隔離級(jí)別相對(duì)應(yīng)

          l         ISOLATION_READ_UNCOMMITTED 這是事務(wù)最低的隔離級(jí)別,它充許別外一個(gè)事務(wù)可以看到這個(gè)事務(wù)未提交的數(shù)據(jù)。這種隔離級(jí)別會(huì)產(chǎn)生臟讀,不可重復(fù)讀和幻像讀。 例如 : Mary的原工資為 1000, 財(cái)務(wù)人員將 Mary 的工資改為了 8000 ,但未提交事務(wù) 與此同時(shí), Mary正在讀取自己的工資 Mary 發(fā)現(xiàn)自己的工資變?yōu)榱?/span> 8000 ,歡天喜地! 而財(cái)務(wù)發(fā)現(xiàn)操作有誤,而回滾了事務(wù) ,Mary 的工資又變?yōu)榱?/span> 1000. 像這樣 ,Mary 記取的工資數(shù) 8000 是一個(gè)臟數(shù)據(jù)。

          l         ISOLATION_READ_COMMITTED 保證一個(gè)事務(wù)修改的數(shù)據(jù)提交后才能被另外一個(gè)事務(wù)讀取。另外一個(gè)事務(wù)不能讀取該事務(wù)未提交的數(shù)據(jù)。這種事務(wù)隔離級(jí)別可以避免臟讀出現(xiàn),但是可能會(huì)出現(xiàn)不可重復(fù)讀和幻像讀。

          l         ISOLATION_REPEATABLE_READ 這種事務(wù)隔離級(jí)別可以防止臟讀,不可重復(fù)讀。但是可能出現(xiàn)幻像讀。它除了保證一個(gè)事務(wù)不能讀取另一個(gè)事務(wù)未提交的數(shù)據(jù)外,還保證了避免下面的情況產(chǎn)生 ( 不可重復(fù)讀 )  在事務(wù) 1 中, Mary 讀取了自己的工資為 1000, 操作并沒有完成 在事務(wù) 2 中,這時(shí)財(cái)務(wù)人員修改了 Mary 的工資為 2000, 并提交了事務(wù) . 在事務(wù) 1 中,Mary 再次讀取自己的工資時(shí),工資變?yōu)榱?/span> 2000 在一個(gè)事務(wù)中前后兩次讀取的結(jié)果并不致,導(dǎo)致了不可重復(fù)讀。 使用 ISOLATION_REPEATABLE_READ 可以避免這種情況發(fā)生。

          l         ISOLATION_SERIALIZABLE 這是花費(fèi)最高代價(jià)但是最可靠的事務(wù)隔離級(jí)別。事務(wù)被處理為順序執(zhí)行。除了防止臟讀,不可重復(fù)讀外,還避免了幻像讀。 目前工資為 1000 的員工有 10人。 事務(wù) 1, 讀取所有工資為 1000 的員工。 共讀取 10 條記錄 這時(shí)另一個(gè)事務(wù)向 employee表插入了一條員工記錄,工資也為 1000 事務(wù) 1 再次讀取所有工資為 1000 的員工 共讀取到了 11 條記錄,這就產(chǎn)生了幻像讀。 ISOLATION_SERIALIZABLE 能避免這樣的情況發(fā)生。但是這樣也耗費(fèi)了最大的資源。

           

           

          getPropagationBehavior () 返回事務(wù)的傳播行為,由是否有一個(gè)活動(dòng)的事務(wù)來決定一個(gè)事務(wù)調(diào)用。  TransactionDefinition 接口中定義了七個(gè)事務(wù)傳播行為:

           

          l         PROPAGATION_REQUIRED 如果存在一個(gè)事務(wù),則支持當(dāng)前事務(wù)。如果沒有事務(wù)則開啟一個(gè)新的事務(wù)。 使用 spring 聲明式事務(wù), spring 使用 AOP 來支持聲明式事務(wù),會(huì)根據(jù)事務(wù)屬性,自動(dòng)在方法調(diào)用之前決定是否開啟一個(gè)事務(wù),并在方法執(zhí)行之后決定事務(wù)提交或回滾事務(wù)。 單獨(dú)調(diào)用 methodB 方法 相當(dāng)于 Spring 保證在 methodB 方法中所有的調(diào)用都獲得到一個(gè)相同的連接。在調(diào)用 methodB 時(shí),沒有一個(gè)存在的事務(wù),所以獲得一個(gè)新的連接,開啟了一個(gè)新的事務(wù)。 單獨(dú)調(diào)用 MethodA 時(shí),在 MethodA 內(nèi)又會(huì)調(diào)用 MethodB. 執(zhí)行效果相當(dāng)于 調(diào)用 MethodA 時(shí),環(huán)境中沒有事務(wù),所以開啟一個(gè)新的事務(wù) . 當(dāng)在 MethodA 中調(diào)用MethodB 時(shí),環(huán)境中已經(jīng)有了一個(gè)事務(wù),所以 methodB 就加入當(dāng)前事務(wù)。

          l         PROPAGATION_SUPPORTS 如果存在一個(gè)事務(wù),支持當(dāng)前事務(wù)。如果沒有事務(wù),則非事務(wù)的執(zhí)行。但是對(duì)于事務(wù)同步的事務(wù)管理器, PROPAGATION_SUPPORTS 與不使用事務(wù)有少許不同。 單純的調(diào)用 methodB 時(shí), methodB 方法是非事務(wù)的執(zhí)行的。 當(dāng)調(diào)用 methdA時(shí) ,methodB 則加入了 methodA 的事務(wù)中 , 事務(wù)地執(zhí)行。

          l         PROPAGATION_MANDATORY 如果已經(jīng)存在一個(gè)事務(wù),支持當(dāng)前事務(wù)。如果沒有一個(gè)活動(dòng)的事務(wù),則拋出異常。 當(dāng)單獨(dú)調(diào)用 methodB 時(shí),因?yàn)楫?dāng)前沒有一個(gè)活動(dòng)的事務(wù),則會(huì)拋出異常 throw new IllegalTransactionStateException("Transaction propagation ''mandatory'' but no existing transaction found"); 當(dāng)調(diào)用 methodA 時(shí), methodB 則加入到 methodA 的事務(wù)中,事務(wù)地執(zhí)行。

          l         PROPAGATION_REQUIRES_NEW 總是開啟一個(gè)新的事務(wù)。如果一個(gè)事務(wù)已經(jīng)存在,則將這個(gè)存在的事務(wù)掛起。 當(dāng)單獨(dú)調(diào)用 methodB 時(shí),相當(dāng)于把 methodb 聲明為 REQUIRED 。開啟一個(gè)新的事務(wù),事務(wù)地執(zhí)行。 當(dāng)調(diào)用 methodA 時(shí) 情況有些大不一樣 . 相當(dāng)于下面的效果。 在這里,我把 ts1 稱為外層事務(wù), ts2 稱為內(nèi)層事務(wù)。從上面的代碼可以看出, ts2 ts1 是兩個(gè)獨(dú)立的事務(wù),互不相干。 Ts2 是否成功并不依賴于 ts1 。如果 methodA 方法在調(diào)用 methodB 方法后的 doSomeThingB 方法失敗了,而 methodB 方法所做的結(jié)果依然被提交。而除了 methodB 之外的其它代碼導(dǎo)致的結(jié)果卻被回滾了。 使用PROPAGATION_REQUIRES_NEW, 需要使用 JtaTransactionManager 作為事務(wù)管理器。

          l         PROPAGATION_NOT_SUPPORTED 總是非事務(wù)地執(zhí)行,并掛起任何存在的事務(wù)。 當(dāng)單獨(dú)調(diào)用 methodB 時(shí),不啟用任何事務(wù)機(jī)制,非事務(wù)地執(zhí)行。 當(dāng)調(diào)用 methodA 時(shí),相當(dāng)于下面的效果 使用 PROPAGATION_NOT_SUPPORTED, 也需要使用 JtaTransactionManager 作為事務(wù)管理器。

          l         PROPAGATION_NEVER 總是非事務(wù)地執(zhí)行,如果存在一個(gè)活動(dòng)事務(wù),則拋出異常 單獨(dú)調(diào)用methodB ,則非事務(wù)的執(zhí)行。 調(diào)用 methodA 則會(huì)拋出異常

          l         PROPAGATION_NESTED 如果一個(gè)活動(dòng)的事務(wù)存在,則運(yùn)行在一個(gè)嵌套的事務(wù)中 . 如果沒有活動(dòng)事務(wù) , 則按 TransactionDefinition.PROPAGATION_REQUIRED 屬性執(zhí)行 這是一個(gè)嵌套事務(wù) , 使用 JDBC 3.0 驅(qū)動(dòng)時(shí) , 僅僅支持 DataSourceTransactionManager 作為事務(wù)管理器。需要 JDBC 驅(qū)動(dòng)的 java.sql.Savepoint 類。有一些 JTA 的事務(wù)管理器實(shí)現(xiàn)可能也提供了同樣的功能。 使用 PROPAGATION_NESTED ,還需要把 PlatformTransactionManager nestedTransactionAllowed 屬性設(shè)為 true;  nestedTransactionAllowed 屬性值默認(rèn)為false; 如果單獨(dú)調(diào)用 methodB 方法,則按 REQUIRED 屬性執(zhí)行。 如果調(diào)用 methodA 方法,相當(dāng)于下面的效果 當(dāng) methodB 方法調(diào)用之前,調(diào)用 setSavepoint 方法,保存當(dāng)前的狀態(tài)到 savepoint 。如果 methodB 方法調(diào)用失敗,則恢復(fù)到之前保存的狀態(tài)。但是需要注意的是,這時(shí)的事務(wù)并沒有進(jìn)行提交,如果后續(xù)的代碼 (doSomeThingB() 方法 ) 調(diào)用失敗,則回滾包括 methodB 方法的所有操作。 嵌套事務(wù)一個(gè)非常重要的概念就是內(nèi)層事務(wù)依賴于外層事務(wù)。外層事務(wù)失敗時(shí),會(huì)回滾內(nèi)層事務(wù)所做的動(dòng)作。而內(nèi)層事務(wù)操作失敗并不會(huì)引起外層事務(wù)的回滾。

           

           

          PROPAGATION_NESTED  PROPAGATION_REQUIRES_NEW 的區(qū)別:

           

          它們非常類似 , 都像一個(gè)嵌套事務(wù),如果不存在一個(gè)活動(dòng)的事務(wù),都會(huì)開啟一個(gè)新的事務(wù)。使用PROPAGATION_REQUIRES_NEW 時(shí),內(nèi)層事務(wù)與外層事務(wù)就像兩個(gè)獨(dú)立的事務(wù)一樣,一旦內(nèi)層事務(wù)進(jìn)行了提交后,外層事務(wù)不能對(duì)其進(jìn)行回滾。兩個(gè)事務(wù)互不影響。兩個(gè)事務(wù)這是一個(gè)真正的嵌套事務(wù)。同時(shí)它需要 JTA 事務(wù)管理器的支持。 使用 PROPAGATION_NESTED 時(shí),外層事務(wù)的回滾可以引起內(nèi)層事務(wù)的回滾。而內(nèi)層事務(wù)的異常并不會(huì)導(dǎo)致外層事務(wù)的回滾,它是一個(gè)真正的嵌套事務(wù)。 DataSourceTransactionManager 使用 savepoint 支持PROPAGATION_NESTED 時(shí),需要 JDBC 3.0 以上驅(qū)動(dòng)及 1.4 以上的 JDK 版本支持。其它的JTA TrasactionManager 實(shí)現(xiàn)可能有不同的支持方式。 PROPAGATION_REQUIRED 應(yīng)該是我們首先的事務(wù)傳播行為。它能夠滿足我們大多數(shù)的事務(wù)需求。

          posted @ 2011-11-29 10:25 Qzi 閱讀(242) | 評(píng)論 (0)編輯 收藏

          參考這篇文章:http://blog.csdn.net/bluishglc/article/details/6632280 
          一。Maven的執(zhí)行方式
          maven對(duì)構(gòu)建(build)的過程進(jìn)行了抽象和定義,這個(gè)過程被稱為構(gòu)建的生命周期(lifecycle)。生命周期(lifecycle)由多個(gè)階段(phase)組成,每個(gè)階段(phase)會(huì)掛接一到多個(gè)goal。goal是maven里定義任務(wù)的最小單元,goal分為兩類,一類是綁定phase的,就是執(zhí)行到某個(gè)phase,那么這個(gè)goal就會(huì)觸發(fā),另外一類不綁定,就是單獨(dú)任務(wù),這就相當(dāng)于ant里的target。
          1。以phase來構(gòu)建
          例如:
          mvn clean
          mvn compile
          mvn test
          mvn package
          表明maven會(huì)執(zhí)行到某個(gè)生命周期(lifecycle)的某個(gè)階段(phase)
          這個(gè)phase以及它前面所有phase綁定的目標(biāo)(goal)都會(huì)執(zhí)行, 每個(gè)phase都會(huì)邦定maven默認(rèn)的goal或者沒有g(shù)oal, 或者自定義的goal。
          也可以通過傳入?yún)?shù)跳過(skip)某些phase,例如:
          mvn install -Dmaven.test.skip=true

          1。以goal來構(gòu)建
          這類就是沒有綁定phase的goal,但是這類goal卻通常會(huì)有個(gè)執(zhí)行前提,就是project必須執(zhí)行到某個(gè)phase,
          那么執(zhí)行這個(gè)goal,其實(shí)也會(huì)觸發(fā)maven執(zhí)行到前提要求的phase。
          例如jetty:run是個(gè)非綁定phase的goal,它的前提是test-compile,這個(gè)前提是由plugin的代碼邏輯制定的

          /**
           * @goal run
           * @requiresDependencyResolution runtime
           * @execute phase="test-compile"
           * @description Runs jetty6 directly from a maven project
           */
          public class Jetty6RunMojo extends AbstractJettyRunMojo
          {
              ...
          }
          二。Maven lifecycle, phase概覽
          Maven預(yù)設(shè)了三個(gè)Lifecycle ,各包含了下列Phases.
          1. Clean Lifecycle
            • pre-clean
            • clean
            • post-clean
          2. Default Lifecycle
            • validate
            • initialize
            • generate-sources
            • process-sources
            • generate-resources
            • process-resources
            • compile
            • process-classes
            • generate-test-sources
            • process-test-sources
            • process-test-resources
            • test-compile
            • process-test-classes
            • test
            • prepare-package
            • package
            • pre-integration-test
            • integration-test
            • post-integration-test
            • verify
            • install
            • deploy
          3. Site Lifecycle
            • pre-site
            • site
            • post-site
            • site-deploy

          posted @ 2011-09-22 10:01 Qzi 閱讀(9290) | 評(píng)論 (0)編輯 收藏

          1.Window
          • java -classpath .;jar1;jar2 MainClass
            注意: -classpath參數(shù)必須放于前面。
          • java -jar jar1
            jar包的MANIFEST.MF文件:
            Manifest-Version: 1.0
            Main-Class: com.Main1
            Class-Path: jar1.jar;jar2.jar

            注意: 使用-jar參數(shù),那么主jar包必須含有MANIFEST.MF信息,并且指定Main-Class & Class-Path。命令行的-classpath參數(shù)將被忽略
          2.Linux
          區(qū)別:
          目錄分隔符由\變成/
          jar包分隔符由;變成:

          Window測試環(huán)境是Sun java version "1.6.0_14"
          其他版本沒有驗(yàn)證

          posted @ 2011-09-16 17:10 Qzi 閱讀(331) | 評(píng)論 (0)編輯 收藏

          posted @ 2011-09-16 16:59 Qzi 閱讀(269) | 評(píng)論 (0)編輯 收藏

          1.綁定本地接口,自動(dòng)生成代理對(duì)象
          復(fù)制下面鏈接代碼
          // Endpoint Address
          String endpointAddress = "http://localhost:8111/helloWorld";
          // Add a port to the Service
          service.addPort(PORT_NAME, SOAPBinding.SOAP11HTTP_BINDING, endpointAddress);
          HelloService hw = service.getPort(HelloService.class);

          posted @ 2011-09-16 16:58 Qzi 閱讀(622) | 評(píng)論 (0)編輯 收藏

          java -Dhttp.proxyHost=127.0.0.1 -Dhttp.proxyPort=8888 -Dhttps.proxyHost=127.0.0.1 -Dhttps.proxyPort=8888

          posted @ 2011-09-16 16:58 Qzi 閱讀(521) | 評(píng)論 (0)編輯 收藏

          Java Keytool Commands for Creating and Importing

          These commands allow you to generate a new Java Keytool keystore file, create a CSR, and import certificates. Any root or intermediate certificates will need to be imported before importing the primary certificate for your domain.

          • Generate a Java keystore and key pair

            keytool -genkey -alias mydomain -keyalg RSA -keystore keystore.jks -keysize 2048

          • Generate a certificate signing request (CSR) for an existing Java keystore

            keytool -certreq -alias mydomain -keystore keystore.jks -file mydomain.csr

          • Import a root or intermediate CA certificate to an existing Java keystore

            keytool -import -trustcacerts -alias root -file Thawte.crt -keystore keystore.jks

          • Import a signed primary certificate to an existing Java keystore

            keytool -import -trustcacerts -alias mydomain -file mydomain.crt -keystore keystore.jks

          • Generate a keystore and self-signed certificate (see How to Create a Self Signed Certificate using Java Keytool for more info)

            keytool -genkey -keyalg RSA -alias selfsigned -keystore keystore.jks -storepass password -validity 360 -keysize 2048

          Java Keytool Commands for Checking

          If you need to check the information within a certificate, or Java keystore, use these commands.

          • Check a stand-alone certificate

            keytool -printcert -v -file mydomain.crt

          • Check which certificates are in a Java keystore

            keytool -list -v -keystore keystore.jks

          • Check a particular keystore entry using an alias

            keytool -list -v -keystore keystore.jks -alias mydomain

          Other Java Keytool Commands

          • Delete a certificate from a Java Keytool keystore

            keytool -delete -alias mydomain -keystore keystore.jks

          • Change a Java keystore password

            keytool -storepasswd -new new_storepass -keystore keystore.jks

          • Export a certificate from a keystore

            keytool -export -alias mydomain -file mydomain.crt -keystore keystore.jks

          • List Trusted CA Certs

            keytool -list -v -keystore $JAVA_HOME/jre/lib/security/cacerts

          • Import New CA into Trusted Certs

            keytool -import -trustcacerts -file /path/to/ca/ca.pem -alias CA_ALIAS -keystore $JAVA_HOME/jre/lib/security/cacerts

          posted @ 2011-09-16 16:24 Qzi 閱讀(395) | 評(píng)論 (0)編輯 收藏

          第一種方式:適合于全部HTML標(biāo)簽
          <acronym title="World Wide Web">
          WWW
          </acronym>

          第二種方式:IMG之類的標(biāo)簽例如:
          <img src="#" alt="鼠標(biāo)移動(dòng)到上方會(huì)顯示并且未加載圖片時(shí)也會(huì)顯示">

          第三種方式:input之類的標(biāo)簽例如:
          <input type="button" value="確定" title="鼠標(biāo)移動(dòng)到上方會(huì)顯示并且未加載圖片時(shí)也會(huì)顯示">

          posted @ 2010-05-28 16:31 Qzi 閱讀(231) | 評(píng)論 (0)編輯 收藏

          第一:簡單的使用axis2包自己實(shí)現(xiàn)調(diào)用

          package common;

          import javax.xml.namespace.QName;
          import org.apache.axis2.AxisFault;
          import org.apache.axis2.addressing.EndpointReference;
          import org.apache.axis2.client.Options;
          import org.apache.axis2.rpc.client.RPCServiceClient;

          public class WebServiceUtils
          {
           // ----------------------------------------------------- Properties
           public static int TIMEOUT = 100000;

           // ----------------------------------------------------- Constructors

           // ----------------------------------------------------- Methods
           /**
            *
            * 調(diào)用axis2的webservice的方法
            *
            * @return
            */
           @SuppressWarnings("unchecked")
           static public Object[] invokeWebService( String url, String nameSpace, String method, Object[] args, Class[] returnTypes )
             throws AxisFault
           {
            RPCServiceClient serviceClient = new RPCServiceClient();
            Options options = serviceClient.getOptions();
            EndpointReference targetEPR = new EndpointReference( url );
            options.setTo( targetEPR );
            options.setTimeOutInMilliSeconds( TIMEOUT );
            QName opName = new QName( nameSpace, method );
            Object[] results = serviceClient.invokeBlocking( opName, args, returnTypes );
            return results;
           }
          }


          第二:

          public static OMElement getEchoOMElement() {
                  OMFactory fac = OMAbstractFactory.getOMFactory();
                  OMNamespace omNs = fac.createOMNamespace(
                          "http://example1.org/example1", "example1");
                  OMElement method = fac.createOMElement("echo", omNs);
                  OMElement value = fac.createOMElement("Text", omNs);
                  value.addChild(fac.createOMText(value, "Axis2 Echo String "));
                  method.addChild(value);

                  return method;
              }

           public static void main(String[] args) {
                  try {
                     OMElement payload = ClientUtil.getEchoOMElement();
                      Options options = new Options();
                    
                      options.setTo(targetEPR);
                      options.setAction("urn:echo");

                      //Blocking invocation
                      ServiceClient sender = new ServiceClient();
                      sender.setOptions(options);
                      OMElement result = sender.sendReceive(payload);

                      System.out.println(result);
                    
                      System.out.println(options.getTo());

                  } catch (AxisFault axisFault) {
                      axisFault.printStackTrace();
                  }
              }

           
          第三:

          利用插件生成客戶端
          private static String URL="http://localhost:8080/axis2/services/WeatherService"; 
              public static void main(String[] args) throws RemoteException {
                  try {
                      WeatherServiceStub stub;
                      if (args != null && args.length != 0) {
                          stub = new WeatherServiceStub(args[0]);
                        
                      } else {
                          stub = new WeatherServiceStub(URL);
                      }
                      WeatherServiceStub.SetWeather setWether = new WeatherServiceStub.SetWeather();
                      WeatherServiceStub.Weather wether = new WeatherServiceStub.Weather();
                    
                      wether.setForecast("east");
                      wether.setRain(true);
                      wether.setTemperature(12.3f);
                      wether.setForecast("big");
                    
                      setWether.setWeather(wether);
                      stub.setWeather(setWether);
                    
                      WeatherServiceStub.GetWeatherResponse gw = new WeatherServiceStub.GetWeatherResponse();
                      System.out.println(gw.get_return());       
                    
                  } catch (AxisFault e) {
                      // TODO Auto-generated catch block
                      e.printStackTrace();
                  }
              }


          本文部分來自CSDN博客,轉(zhuǎn)載請(qǐng)標(biāo)明出處:http://blog.csdn.net/yhhah/archive/2009/05/07/4158487.aspx

          posted @ 2010-01-20 23:16 Qzi 閱讀(10508) | 評(píng)論 (0)編輯 收藏

          主站蜘蛛池模板: 苍南县| 社旗县| 凉城县| 中方县| 蚌埠市| 逊克县| 晋州市| 汝阳县| 巢湖市| 蕲春县| 西吉县| 弋阳县| 嵩明县| 青河县| 廊坊市| 赤城县| 博客| 阿图什市| 吉木萨尔县| 巴林右旗| 和平县| 保靖县| 安化县| 齐河县| 五华县| 乌审旗| 达尔| 上杭县| 都匀市| 云和县| 大足县| 庐江县| 米脂县| 清河县| 东兴市| 大理市| 从江县| 若羌县| 秀山| 友谊县| 肇东市|