今日, 本人在tomcat+spring mvc平台的服務器上遇到java.lang.IllegalStateException: Optional int parameter 'id' is not present異常, 很是怪異, mvc方法里面的id為int型, 明明是有值的, 為什么說沒有? 改為Integer也不行, mvc方法直接無響應!
然后, 在本地模擬改用例, 發現可以正常執行, 而另一個同事說要把超長的圖片參數放到Mvc方法的最后就可以正常訪問! 怪異!
后來經過多次試驗, 發現是其他參數的長度很長很長,例如存放圖片的base64, 可能會超出tomcat的默認的post最多長度(2M), 但是網上很多人說超長拋出的異常應該是"post too large", 但是卻拋出了另一種異常: :java.lang.IllegalStateException: Optional int parameter 'id' is not prese nt but cannot be translated into a null value due to being declared as a primiti ve type. Consider declaring it as object wrapper for the corresponding primitive type.
本人的理解是sping mvc忽略了post too large異常, 直接對請求參數內容進行截取, 導致了id參數為空, 因此才出現了這樣怪異的現象.
解決的辦法當然就是在tomcat的server.xml里面加一個maxPostSize="0"