關(guān)于java.lang.NumberFormatException: null的問題及解決
java.lang.NumberFormatException: null
不知道大家有沒有像我一樣常常因為在代碼中多加了一個空格或名字寫錯一個字母,在報錯后找半天都找不出來錯在哪,叫同事來幫忙解決,找到問題所在后真的想狠狠給自己一巴掌,總是犯這種低級錯誤,有被無語到~
接下來進入正題
我想點擊對應的更新|刪除 時跳轉(zhuǎn)到對應的頁面,代碼如下:
<c:forEach items="${listManager}" var="manager"> <tr class="tr2"> <td>${manager.id}</td> <td>${manager.name}</td> <td>${manager.price}</td> <td>${manager.introduce}</td> <td><a href="<%=path%>/cn/servlet/ManagerServlet?flag = update & m_id =${manager.id}" rel="external nofollow" >更新</a> <a href="<%=path%>/cn/servlet/ManagerServlet? flag =delete & m_id= ${manager.getId()}" rel="external nofollow" >刪除</a> </td> </tr> </c:forEach>
對應的MangerServlet代碼:
if (flag.equals("delete")){ System.out.println("=======delete"+flag); String m_id = req.getParameter("m_id"); System.out.println(m_id); //將String類型的m_id轉(zhuǎn)換成int型 Integer id = Integer.parseInt(m_id.trim()); System.out.println("---id--"+id); ManagerDao managerDao = new ManagerDao(); int m = managerDao.delManager(id); String path = ""; if (m==1){ List<Manager>listManager ; listManager = managerDao.list(); // HttpSession session = req.getSession(); //session.setAttribute("listManager",listManager); req.setAttribute("listManager",listManager); path="/manager/menu.jsp"; }else { path = "/error.jsp"; } RequestDispatcher dispatcher = req.getRequestDispatcher(path); dispatcher.forward(req,resp); }else if (flag.equals("update")){ System.out.println("=======update"+flag); String m_id = req.getParameter("m_id"); System.out.println(m_id); int id = Integer.parseInt(m_id); ManagerDao managerDao = new ManagerDao(); Manager manager = managerDao.getManager(id); req.setAttribute("manager",manager); RequestDispatcher dispatcher = req.getRequestDispatcher("/manager/update.jsp"); dispatcher.forward(req,resp);
ManagerDao層代碼:
public int delManager(int id) { //數(shù)據(jù)庫連接、 Connection conn = JDBC.getConnection(); Statement state = null; // System.out.println(u); try { state = conn.createStatement(); String sql = "delete from menus where id="+id; System.out.println(sql); m = state.executeUpdate(sql); } catch (SQLException throwables) { throwables.printStackTrace(); } JDBC.close(conn, state,null); return m; } public Manager getManager(int id) { //數(shù)據(jù)庫連接、 Connection conn = JDBC.getConnection(); Statement state = null; //局部變量沒有初始值 Manager manager = null; // System.out.println(u); try { state = conn.createStatement(); String sql = "select * from menus where id="+id; ResultSet rs = state.executeQuery(sql); if(rs.next()){ manager = new Manager(); manager.setId(rs.getInt(1)); manager.setName(rs.getString(2)); manager.setPrice(rs.getString(3)); //manager.setPrice(rs.getBigDecimal(3)); manager.setIntroduce(rs.getString(4)); } } catch (SQLException throwables) { throwables.printStackTrace(); } JDBC.close(conn, state,null); return manager; }
運行結(jié)果錯誤截圖
去網(wǎng)上找嘗試了各種方法都沒能解決,
最后叫來了朋友幫忙看,最后她說這里不能有空格,否則就會報500的錯誤,
還有我把update寫成了updata,然后界面怎么都跳不過去報錯,我都服了我自己...
總結(jié)
1.大部分時候是類型轉(zhuǎn)化的問題
比如這樣轉(zhuǎn)化:
int state = Integer.parseInt(request.getParameter(“state”))
在轉(zhuǎn)換過程中可能存在空格,或者傳遞url值的時候忘了傳遞參數(shù),或者傳遞錯誤,導致獲取到的值為null。
還有一種就是低級錯誤了,就是mysql·或者你·寫的數(shù)據(jù)庫里,有參數(shù)是空的,就會導致問題出現(xiàn)得把參數(shù)值補上,不能有空缺。
2.解決方法
2.1.在轉(zhuǎn)換之前去空格,Integer.parseInt(numString.trim()) ;
2.2.在轉(zhuǎn)換之前判空串:if(s!=""){轉(zhuǎn)換}
2.3.在轉(zhuǎn)換之前判空:if(s!=null){轉(zhuǎn)換}
在適當?shù)奈恢锰砑涌刂婆_打印語句,方便檢查那一語句出錯。
最后,敲代碼一定要細心 細心 再耐心吶~~~
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
springMVC+jersey實現(xiàn)跨服務器文件上傳
這篇文章主要介紹了springMVC+jersey實現(xiàn)跨服務器文件上傳,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-08-08RocketMQ消息隊列實現(xiàn)隨機消息發(fā)送當做七夕禮物
這篇文章主要為大家介紹了RocketMQ消息隊列實現(xiàn)隨機消息發(fā)送當做七夕禮物,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-08-08Java如何處理數(shù)據(jù)成為樹狀結(jié)構(gòu)
這篇文章主要介紹了Java如何處理數(shù)據(jù)成為樹狀結(jié)構(gòu)問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-07-07Java實現(xiàn)PDF轉(zhuǎn)Word的示例代碼(無水印無頁數(shù)限制)
這篇文章主要為大家詳細介紹了如何利用Java語言實現(xiàn)PDF轉(zhuǎn)Word文件的效果,并可以無水印、無頁數(shù)限制。文中的示例代碼講解詳細,需要的可以參考一下2022-05-05