Java, Only Java!

          統計

          留言簿(20)

          積分與排名

          好友空間

          文檔技巧

          閱讀排行榜

          評論排行榜

          在Tomcat上開發Web應用如何保證兼容性

          最近,協助伙伴將Tomcat上開發的應用向Apusic移植時發現了一個兼容性問題。
          應用中代碼為:HashMap params = (HashMap) request.getParameterMap();

          而getParameterMap()在JCP規范中的定義為:
          public java.util.Map getParameterMap()
          Returns a java.util.Map of the parameters of this request. Request parameters are extra information sent with the request. For HTTP servlets, parameters are contained in the query string or posted form data.
          請求的參數將返回一個java.util.Map。請求參數是請求發送的特別信息。對于HTTP servlets來說,參數包含在查詢字符串或者發出的表單數據中。

          Returns: an immutable java.util.Map containing parameter names as keys and parameter values as map values. The keys in the parameter map are of type String. The values in the parameter map are of type String array.
          一個不可更改的java.util.Map包含參數名稱(關鍵字)和參數值(映射值)。參數映射中的關鍵字是String類型。參數映射中的值是String數組類型。

          可見規范中定義的返回值只是Map類型,而沒有強制為HashMap。
          Apusic在實現的時候也是Map作為返回值,而Tomcat返回時(參考org.apache.catalina.connector.Request.java)就是一個擴展自HashMap的ParameterMap類,因此開發時如何作為Map來用也不會出現問題,但是如果強制轉換成HashMap就可能會與其他應用服務器產品無法正確兼容。

          Tomcat是一款非常不錯的開源Web服務器,許多公司在軟件開發時都使用Tomcat作為Web容器,并且Tomcat也較好的對Servlet和JSP規范進行了支持,因此許多在Tomcat上開發的應用都可以向其他商業應用服務器上進行移植。

          但是,Tomcat因為未去通過規范測試,因此可能會存在沒有完全參考規范實現的部分,因此在開發中建議開發人員去www.jcp.org上去下載一個規范來進行參考,開發過程中盡可能按照規范給定的參數和返回值來使用系統的核心功能,從而避免在移植中出現不必要的問題。

          附注:出現問題也不可怕,總有許多方式可以解決,就如上文出現的Map與HashMap的問題。其實網上有許多Map向HashMap轉換的代碼,可以增加個過渡參數將得到的Map進行一次轉換就可以不修改其他業務代碼了。

          posted on 2008-08-14 07:42 zYx.Tom 閱讀(1897) 評論(7)  編輯  收藏 所屬分類: 1.Java世界

          評論

          # re: 在Tomcat上開發Web應用如何保證兼容性 2008-08-14 08:38 Hatter Jiang

          暈,就是應該使用Map的,為什么要強制類型轉換為HashMap呢,要記錄依賴上層,而不能依賴下層  回復  更多評論   

          # re: 在Tomcat上開發Web應用如何保證兼容性 2008-08-14 08:43 wxm

          這是開發者的問題,不能說是Tomcat未通過規范測試,jee上說返回的是Map,開發者強轉為HashMap是不對的了  回復  更多評論   

          # re: 在Tomcat上開發Web應用如何保證兼容性 2008-08-14 09:05 朱遠翔-Apusic技術顧問

          呵呵,都認為是開發者的問題。

          其實,這篇文章也是想提醒程序員們注意規劃,而不僅僅是Map與HashMap

          因為還有許多朋友做J2EE開發確從沒有了解過規范,希望這篇文章能夠幫助他們在開發期就能避免這樣的失誤,以免后期上線時再來修改代碼從而增加項目的成本與風險。  回復  更多評論   

          # re: 在Tomcat上開發Web應用如何保證兼容性 2008-08-14 14:32 小高

          以用前面 那個兄弟的話 :"希望這篇文章能夠幫助他們在開發期就能避免這樣的失誤,以免后期上線時再來修改代碼從而增加項目的成本與風險。"

          說的很好.  回復  更多評論   

          # re: 在Tomcat上開發Web應用如何保證兼容性 2008-08-14 21:04 Apusic門外漢

          在Apusic上開發Web應用如何保證兼容性

          最近,協助伙伴將Apusic上開發的應用向Tomcat移植時發現了一個兼容性問題。
          應用中代碼為:HashMap params = (HashMap) request.getParameterMap();

          而getParameterMap()在JCP規范中的定義為:
          public java.util.Map getParameterMap()
          Returns a java.util.Map of the parameters of this request. Request parameters are extra information sent with the request. For HTTP servlets, parameters are contained in the query string or posted form data.
          請求的參數將返回一個java.util.Map。請求參數是請求發送的特別信息。對于HTTP servlets來說,參數包含在查詢字符串或者發出的表單數據中。

          Returns: an immutable java.util.Map containing parameter names as keys and parameter values as map values. The keys in the parameter map are of type String. The values in the parameter map are of type String array.
          一個不可更改的java.util.Map包含參數名稱(關鍵字)和參數值(映射值)。參數映射中的關鍵字是String類型。參數映射中的值是String數組類型。

          可見規范中定義的返回值只是Map類型,而沒有強制為HashMap。
          Tomcat 在實現的時候也是Map作為返回值,而Apusic返回時(參考 org.apache.catalina.connector.Request.java)就是一個擴展自HashMap的ParameterMap類,因此開發時如何作為Map來用也不會出現問題,但是如果強制轉換成HashMap就可能會與其他應用服務器產品無法正確兼容。

          Apusic是一款非常不錯的開源Web服務器,許多公司在軟件開發時都使用Apusic作為Web容器,并且Apusic也較好的對Servlet和JSP規范進行了支持,因此許多在Apusic上開發的應用都可以向其他商業應用服務器上進行移植。

          但是,Apusic因為未去通過規范測試,因此可能會存在沒有完全參考規范實現的部分,因此在開發中建議開發人員去www.jcp.org上去下載一個規范來進行參考,開發過程中盡可能按照規范給定的參數和返回值來使用系統的核心功能,從而避免在移植中出現不必要的問題。

          附注:出現問題也不可怕,總有許多方式可以解決,就如上文出現的Map與HashMap的問題。其實網上有許多Map向HashMap轉換的代碼,可以增加個過渡參數將得到的Map進行一次轉換就可以不修改其他業務代碼了。   回復  更多評論   

          # re: 在Tomcat上開發Web應用如何保證兼容性 2008-08-15 00:38 隔葉黃鶯

          Tomcat 不應該受此罪責,它完全沒有問題啊

          規范是返回 Map,Tomcat 怎么實現 Map 全是它自己的事。

          要說規范,那么我在 WAS5.1下的 request 好像還沒有 getParameterMap() 這個方法呢?  回復  更多評論   

          # re: 在Tomcat上開發Web應用如何保證兼容性 2008-08-15 16:27 朱遠翔-Apusic技術顧問

          @隔葉黃鶯
          本文沒有指責Tomcat有問題,但是Tomcat在實現的時候確實留下了誤用的通道。
          就如C/C++用不好會有內存泄漏,當然這個不是語言的問題,而是程序員的問題,而本文也是希望程序員在用Tomcat的時候注意不要因為誤用而給未來的移植帶來困難。

          WAS V5.1不支持getParameterMap()這個方法是因為WAS V5.1只通過了J2EE 1.3的規范,他的WEB容器只需要實現Servlet 2.3規范,這個方法是在J2EE 1.4(Servlet 2.4)中才加入的。
          規范認證請參考下面的鏈接:
          http://java.sun.com/j2ee/compatibility_1.3.html

          Servlet 2.4認證可以到www.jcp.org上下載servlet-2_4-fr-spec.pdf,在PDF文件的P284有說明增加了這個方法:
          Add missing getParameterMap() in the enumerated list (4.1)  回復  更多評論   

          主站蜘蛛池模板: 固阳县| 扎兰屯市| 屏东市| 宁国市| 宽甸| 乐都县| 广汉市| 靖宇县| 大英县| 阜平县| 西峡县| 铜川市| 阿瓦提县| 丹江口市| 攀枝花市| 西藏| 土默特左旗| 嘉禾县| 卓尼县| 静海县| 会宁县| 英超| 大厂| 甘洛县| 舟曲县| 博兴县| 松阳县| 通河县| 都兰县| 马尔康县| 淮南市| 吉隆县| 祁阳县| 甘孜| 鹤壁市| 屏山县| 兰西县| 梅州市| 天水市| 天镇县| 永胜县|