最近,協助伙伴將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進行一次轉換就可以不修改其他業務代碼了。