標簽" />

日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

Tomcat 6、7在EL表達式解析時存在的一個Bug

系統 2162 0

本文出處: http://blog.csdn.net/chaijunkun/article/details/9097229 ,轉載請注明。由于本人不定期會整理相關博文,會對相應內容作出完善。因此強烈建議在原始出處查看此文。

今天在做數據分頁顯示的時候遇到了一個問題,經過測試,證實是Tomcat 6的一個bug,我所用的版本為:apache-tomcat-6.0.36,和7.0.30均能復現。下面詳細描述一下這個bug:

該bug是在JSTL<c:forEach>標簽中發現的,后來分析是EL表達式實現時產生的問題。jsp頁面中有一個list需要遍歷,這個list的類型為ArrayList<String>,我在其中放置的數據為(為方便我寫成數組的形式):["1","..." ,"4" ,"5" ,"6" ,"7" ,"8" ,"..." ,"10" ],這是一個很常見的帶頁碼縮略的分頁導航。在展示這些數據的時候我使用了下面的代碼:

?

    <c:forEach var="looper" items="${pageHelper.pageList}">

	<c:choose>

		<c:when test="${looper eq pageHelper.pageDot}">

		<p>分頁游標的 點點點</p>

		</c:when>

		<c:when test="${looper eq pageHelper.pageNo}">

		<p>當前頁為第${looper}頁面</p>

		</c:when>

		<c:otherwise>

		<p>分頁游標:${looper}</p>

		</c:otherwise>

	</c:choose>

</c:forEach>
  


這里pageHelper就是分頁組件,其中預設了pageDot為"...",pageNo為當前的頁碼(假設為6),其他情況直接顯示分頁游標。在循環遍歷中只不過使用了最基本的條件判斷語句,由于pageList在定義中已經明確指出是List<String>,按邏輯應該eq是按照字符串判斷的,但是居然出異常了:

?

?

    javax.el.ELException: Cannot convert ... of type class java.lang.String to class java.lang.Long
  

為什么會出現“類型轉換錯誤”呢?通過分析代碼走向,當進入循環后,list中的第一條數據是“1”,而pageHelper.pageNo為long型,此時tomcat的EL表達式解析器會把looper類型轉換為Long型而不是把pageHelper.pageNo類型轉換為String進行比較,當遍歷到下一元素時,looper="...",這時looper的類型已經確定,比較的時候tomcat還要試圖將looper轉換為Long類型,于是就出錯了。

?

為此我專門寫了一個實例代碼:

?

    <c:forEach var="looper" items="${pageHelper.pageList}">

	<c:choose>

		<c:when test="${looper eq fn:trim(pageHelper.pageDot)}">

		<p>分頁游標的 點點點</p>

		</c:when>

		<c:when test="${looper eq fn:trim(pageHelper.pageNo)}">

		<p>當前頁為第${looper}頁面</p>

		</c:when>

		<c:otherwise>

		<p>分頁游標:${looper}</p>

		</c:otherwise>

	</c:choose>

</c:forEach>
  


很簡單,每次比較的時候都把后者用fn:trim方法進行去除左右非可見字符。相當于強制轉換為String類型,此時tomcat又可以正常解析代碼,并未報錯。

?

同樣的一套代碼,我將其部署到resin中發現無論是修改前還是修改后都能正常運行,可見,應該是tomcat的bug。

示例代碼下載地址: http://download.csdn.net/detail/chaijunkun/5581883

讓tomcat報錯的演示地址: /bug/show.do

避免此bug的方法演示地址:/bug/avoid.do

以上地址前可能需要加上項目名稱(具體取決于你如何部署該項目)

?

Tomcat 6、7在EL表達式解析時存在的一個Bug


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 临泉县| 响水县| 仪征市| 永福县| 裕民县| 西吉县| 集安市| 佛冈县| 若尔盖县| 遵义市| 潜山县| 揭西县| 七台河市| 名山县| 乐业县| 保德县| 梅河口市| 同心县| 江永县| 夏邑县| 民乐县| 丽江市| 乐山市| 夏邑县| 宜良县| 山东| 恩施市| 夏津县| 永顺县| 吕梁市| 连城县| 阿坝县| 和平区| 关岭| 德惠市| 双桥区| 阜南县| 平定县| 呼图壁县| 阿拉善盟| 景泰县|