最近協助伙伴將Tomcat上開發的應用向Apusic移植時發現了一個兼容性問題
應用中代碼為HashMap params = (HashMap) requestgetParameterMap();
而getParameterMap()在JCP規范中的定義為public javautilMap getParameterMap()
Returns a javautilMap 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請求的參數將返回一個javautilMap請求參數是請求發送的特別信息對於HTTP servlets來說參數包含在查詢字符串或者發出的表單數據中
Returns an immutable javautilMap 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一個不可更改的javautilMap包含參數名稱(關鍵字)和參數值(映射值)參數映射中的關鍵字是String類型參數映射中的值是String數組類型
可見規范中定義的返回值只是Map類型而沒有強制為HashMap Apusic在實現的時候也是Map作為返回值而Tomcat返回時(參考 orgapachecatalinaconnectorRequestjava)就是一個擴展自HashMap的ParameterMap類因此開發時如何作為Map來用也不會出現問題但是如果強制轉換成HashMap就可能會與其他應用服務器產品無法正確兼容
Tomcat是一款非常不錯的開源Web服務器許多公司在軟件開發時都使用Tomcat作為Web容器並且Tomcat也較好的對Servlet和JSP規范進行了支持因此許多在Tomcat上開發的應用都可以向其他商業應用服務器上進行移植
但是Tomcat因為未去通過規范測試因此可能會存在沒有完全參考規范實現的部分因此在開發中建議開發人員去wwwjcporg上去下載一個規范來進行參考開發過程中盡可能按照規范給定的參數和返回值來使用系統的核心功能從而避免在移植中出現不必要的問題
附注出現問題也不可怕總有許多方式可以解決就如上文出現的Map與HashMap的問題其實網上有許多Map向HashMap轉換的代碼可以增加個過渡參數將得到的Map進行一次轉換就可以不修改其他業務代碼了
From:http://tw.wingwit.com/Article/program/Java/ky/201311/28971.html