竹里館→憶童年

          獨(dú)坐幽篁里,彈琴?gòu)?fù)長(zhǎng)嘯;深林人不知,明月來(lái)相照
          posts - 9, comments - 23, trackbacks - 0, articles - 0
             :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 ::  :: 管理

              終于,使用Java完成了一個(gè)WebService的例子,其中的一個(gè)非常小的問(wèn)題,折騰了我將近一天的時(shí)間。下面給出步驟,說(shuō)明在Java平臺(tái)上如何開發(fā)WebService。

              采用的工具:Eclipse3.1.2 + Tomcat5.5 + XFire1.1 。使用XFire開發(fā)WebService應(yīng)該說(shuō)非常的容易,只需要按照下面例子的步驟來(lái)做:

          (1)在Eclipse中新建一個(gè)dynamic Web Project ,假設(shè)名為XFireZhuweiTest。

          (2)導(dǎo)入XFire用戶庫(kù)。該庫(kù)中應(yīng)包含xfire-1.1目錄下的xfire-all-1.1.jar文件,以及xfire-1.1\lib目錄下的所有文件。

          (3)將上述的XFire用戶庫(kù)中的所有文件拷貝到XFireZhuweiTest項(xiàng)目的WebContent\WEB-INF\lib目錄下。

          (4)修改WebContent\WEB-INF\web.xml配置文件的內(nèi)容,下面是修改后web.xml:

          <?xml version="1.0" encoding="UTF-8"?>
          <web-app id="WebApp_ID" version="2.4" xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
              <display-name>
              XFireZhuweiTest</display-name>
              <welcome-file-list>
                  <welcome-file>index.html</welcome-file>
                  <welcome-file>index.htm</welcome-file>
                  <welcome-file>index.jsp</welcome-file>
                  <welcome-file>default.html</welcome-file>
                  <welcome-file>default.htm</welcome-file>
                  <welcome-file>default.jsp</welcome-file>
              </welcome-file-list>
              
              <servlet>
                   <servlet-name>XFireServlet</servlet-name>
                   <servlet-class>
                           org.codehaus.xfire.transport.http.XFireConfigurableServlet
                   </servlet-class>
               </servlet>
               
               <servlet-mapping>
                   <servlet-name>XFireServlet</servlet-name>
                   <url-pattern>/servlet/XFireServlet/*</url-pattern>
               </servlet-mapping>
           
               <servlet-mapping>
                   <servlet-name>XFireServlet</servlet-name>
                    <url-pattern>/services/*</url-pattern>
               </servlet-mapping>
              
          </web-app>

              web.xml中添加的servlet映射表明,所有匹配“/services/*”的url請(qǐng)求全部交給org.codehaus.xfire.transport.http.XFireConfigurableServlet來(lái)處理。

          (5)編寫需要發(fā)布為WebService的Java類,這個(gè)例子中是一個(gè)非常簡(jiǎn)單的MathService.java。

          package com.zhuweisky.xfireDemo;
          public class MathService 
          {
              
          public int Add(int a ,int b)
              {
                  
          return a+b ;
              }
          }

          (6)在WebContent\META-INF目錄下新建xfire文件夾,然后在xfire目錄下添加一個(gè)XFire使用的配置文件services.xml,該配置文件中的內(nèi)容反映了要將哪些java類發(fā)布為web服務(wù)。本例中的services.xml內(nèi)容如下:

          <?xml version="1.0" encoding="UTF-8"?>
          <beans xmlns="http://xfire.codehaus.org/config/1.0">
              
          <service>
                
          <name>MathService</name>
                
          <namespace>http://com.zhuweisky.xfireDemo/MathService</namespace>
                <serviceClass>com.zhuweisky.xfireDemo.MathService</serviceClass>
              
          </service>
          </beans>


              XFire會(huì)借助Spring來(lái)解析services.xml,從中提取需要發(fā)布為WebService的配置信息。

              很多文章介紹到這里就完了,然而當(dāng)我按照他們所說(shuō)的啟動(dòng)WebService ,然后通過(guò)http://localhost:8080/XFireZhuweiTest/services/MathService?wsdl 來(lái)訪問(wèn)服務(wù)描述時(shí),卻拋出了異常,說(shuō)services.xml文件不存在--
          “org.springframework.beans.factory.BeanDefinitionStoreException: IOException parsing XML document from class path resource [META-INF/xfire/services.xml]; nested exception is java.io.FileNotFoundException: class path resource [META-INF/xfire/services.xml] cannot be opened because it does not exist”。  

          (7)非常關(guān)鍵的一點(diǎn),就是這個(gè)小難題花費(fèi)了我將近一天的時(shí)間。
              在WebContent\WEB-INF目錄下新建classes文件夾,然后需要將WebContent下的整個(gè)META-INF文件夾剪切到新建的classes文件夾下。
              到這里,項(xiàng)目的完整目錄結(jié)構(gòu)如下:


            (8)在處理完這個(gè)問(wèn)題后.從新部署并運(yùn)Tomcat.但接著問(wèn)題又來(lái)了錯(cuò)誤內(nèi)容如下:Unrecognized xbean element mapping: services in namespace                          http://xfire.codeh.
                     經(jīng)過(guò)分析得出XFire1.26需要xalan.jar包的支持.但它自身的Lib下無(wú)此jar。需要我們?cè)赼pache官方下載.然后將此包放入工程的lib下
            (9)再次從新編譯運(yùn)行.本以為一切OK了.但還是出來(lái)問(wèn)題java.lang.NoClassDefFoundError: org/apache/xml/serializer/TreeWalker錯(cuò)誤
                      這次通過(guò)在Apache官方找到了出錯(cuò)誤的原因:
                      原本這個(gè)類是包含在xalan.jar中的,但是xalan-j2.7.0版的發(fā)布包中,將serializer包中的類單獨(dú)打包成serializer.jar,不再包含在xalan.jar中,所以才會(huì)即使添加了
                      xalan.jar也無(wú)法找到該類,添加后即可解決問(wèn)題
           (10)OK。一切搞定在IE中輸入 http://localhost:8080/XFireZhuweiTest/services/MathService?wsdl 會(huì)得到正確的web服務(wù)描述文檔
             


          評(píng)論

          # re: XFire+MyEclipse+Tomcat6.0開發(fā)Webservice中遇到問(wèn)題及解決方案(初級(jí))[未登錄](méi)  回復(fù)  更多評(píng)論   

          2007-08-15 17:31 by Aqing
          Xfire配合Spring的話,配置會(huì)更簡(jiǎn)單,呵呵

          # re: XFire+MyEclipse+Tomcat6.0開發(fā)Webservice中遇到問(wèn)題及解決方案(初級(jí))  回復(fù)  更多評(píng)論   

          2007-08-18 09:31 by ianwong
          我也遇到這個(gè)問(wèn)題,不知道與你是否完全一樣? 把您說(shuō)的兩個(gè)包放進(jìn)去以后,問(wèn)題依舊,好郁悶
          Servlet threw load() exception
          org.springframework.beans.factory.BeanDefinitionStoreException: Unrecognized xbean element mapping: beans in namespace http://xfire.codehaus.org/config/1.0
          at org.apache.xbean.spring.context.v2a.XBeanNamespaceHandler.parseBeanFromExtensionElement(XBeanNamespaceHandler.java:258)
          at org.apache.xbean.spring.context.v2a.XBeanNamespaceHandler.parse(XBeanNamespaceHandler.java:152)
          at org.apache.xbean.spring.context.v2.XBeanNamespaceHandler.parse(XBeanNamespaceHandler.java:49)

          # re: XFire+MyEclipse+Tomcat6.0開發(fā)Webservice中遇到問(wèn)題及解決方案(初級(jí))[未登錄](méi)  回復(fù)  更多評(píng)論   

          2007-08-20 09:50 by 蕭蕭牛郎
          @ianwong兄.你的問(wèn)題我也不太清楚。你可否加我QQ:285203392我?guī)湍憧纯?

          # re: XFire+MyEclipse+Tomcat6.0開發(fā)Webservice中遇到問(wèn)題及解決方案(初級(jí))  回復(fù)  更多評(píng)論   

          2007-08-30 18:52 by goto
          你好,我也剛做了可簡(jiǎn)單的例子,可是寫客戶端時(shí),老是報(bào)這樣的錯(cuò)誤
          Exception in thread "main" java.lang.ExceptionInInitializerError
          at org.codehaus.xfire.DefaultXFire.<init>(DefaultXFire.java:37)
          at org.codehaus.xfire.XFireFactory.<init>(XFireFactory.java:36)
          at org.codehaus.xfire.XFireFactory.newInstance(XFireFactory.java:61)
          at org.codehaus.xfire.service.binding.ObjectServiceFactory.<init>(ObjectServiceFactory.java:112)
          at client.Client.main(Client.java:37)
          Caused by: org.apache.commons.logging.LogConfigurationException: org.apache.commons.logging.LogConfigurationException: java.lang.NullPointerException (Caused by java.lang.NullPointerException) (Caused by org.apache.commons.logging.LogConfigurationException: java.lang.NullPointerException (Caused by java.lang.NullPointerException))
          at org.apache.commons.logging.impl.LogFactoryImpl.newInstance(LogFactoryImpl.java:543)
          at org.apache.commons.logging.impl.LogFactoryImpl.getInstance(LogFactoryImpl.java:235)
          at org.apache.commons.logging.impl.LogFactoryImpl.getInstance(LogFactoryImpl.java:209)
          at org.apache.commons.logging.LogFactory.getLog(LogFactory.java:351)
          at org.codehaus.xfire.transport.DefaultTransportManager.<clinit>(DefaultTransportManager.java:26)
          ... 5 more
          Caused by: org.apache.commons.logging.LogConfigurationException: java.lang.NullPointerException (Caused by java.lang.NullPointerException)
          at org.apache.commons.logging.impl.LogFactoryImpl.getLogConstructor(LogFactoryImpl.java:397)
          at org.apache.commons.logging.impl.LogFactoryImpl.newInstance(LogFactoryImpl.java:529)
          ... 9 more
          Caused by: java.lang.NullPointerException
          at org.apache.commons.logging.impl.LogFactoryImpl.getLogConstructor(LogFactoryImpl.java:374)
          ... 10 more

          難道還需要log嗎,真是郁悶

          # re: XFire+MyEclipse+Tomcat6.0開發(fā)Webservice中遇到問(wèn)題及解決方案(初級(jí))[未登錄](méi)  回復(fù)  更多評(píng)論   

          2007-10-11 18:16 by Anson
          Have you fixed the problem?

          # re: XFire+MyEclipse+Tomcat6.0開發(fā)Webservice中遇到問(wèn)題及解決方案(初級(jí))[未登錄](méi)  回復(fù)  更多評(píng)論   

          2007-12-29 10:00 by Alex
          如果使用 spring2.0 版本以上。
          需要修改services.xml 成如下形式:
          <beans>
          <service xmlns="http://xfire.codehaus.org/config/1.0">" target="_new" rel="nofollow">http://xfire.codehaus.org/config/1.0">
          <name>...</name>
          ...
          </service>
          </beans>

          否則一直會(huì):org.springframework.beans.factory.BeanDefinitionStoreException: Unrecognized xbean element mapping: beans in namespace http://xfire.codehaus.org/config/1.0

          # re: XFire+MyEclipse+Tomcat6.0開發(fā)Webservice中遇到問(wèn)題及解決方案(初級(jí))  回復(fù)  更多評(píng)論   

          2008-12-03 17:31 by mm
          <service xmlns="http://xfire.codehaus.org/config/1.0">"" target="_new" rel="nofollow">http://xfire.codehaus.org/config/1.0">" target="_new" rel="nofollow">http://xfire.codehaus.org/config/1.0">


          這里格式要是怎能么樣的?

          # re: XFire+MyEclipse+Tomcat6.0開發(fā)Webservice中遇到問(wèn)題及解決方案(初級(jí))  回復(fù)  更多評(píng)論   

          2008-12-06 20:15 by 你好
          謝謝了

          # re: XFire+MyEclipse+Tomcat6.0開發(fā)Webservice中遇到問(wèn)題及解決方案(初級(jí))  回復(fù)  更多評(píng)論   

          2009-03-13 14:33 by sssss
          Spring 2.x support
          Because of Spring 2.x new feature, services.xml default namespace must not be declared on the root element of configuration ( beans ) and need to be moved to <service> tag level.



          <beans>
          <service xmlns="http://xfire.codehaus.org/config/1.0">
          <name/>
          <namespace/>
          ...
          ...
          </service>
          </beans>

          # re: XFire+MyEclipse+Tomcat6.0開發(fā)Webservice中遇到問(wèn)題及解決方案(初級(jí))  回復(fù)  更多評(píng)論   

          2009-03-13 14:36 by sssss
          上面的答案是在官方網(wǎng)站上找到的,我覺(jué)得以后有問(wèn)題大家還是上官方網(wǎng)找比較好,一針見(jiàn)血!

          # re: XFire+MyEclipse+Tomcat6.0開發(fā)Webservice中遇到問(wèn)題及解決方案(初級(jí))  回復(fù)  更多評(píng)論   

          2010-10-13 11:55 by 張輝武
          謝謝!
          主站蜘蛛池模板: 岚皋县| 泊头市| 太仓市| 白沙| 北流市| 建始县| 湖南省| 和硕县| 河曲县| 阆中市| 秭归县| 济阳县| 基隆市| 清流县| 南开区| 永康市| 江北区| 布拖县| 榆中县| 莱阳市| 安达市| 浮梁县| 泽州县| 吴川市| 日照市| 太康县| 建瓯市| 鄢陵县| 巴东县| 南昌县| 涟水县| 南召县| 平邑县| 香港| 海阳市| 筠连县| 石楼县| 洛阳市| 星座| 衡阳市| 石屏县|