JSP Model2 留言板这个Servlet毕业项目 断断续续也写了好几天了 明天就应该写完了
今天来记录一下这几天来遇上的问题与解决方法 还有一些不解的地方
-
第一个问题是遇上了一个java.lang.NullPointerException问题
这个问题 比较常见但是报错 有些看不懂
报错的分别报错
两个方法
doGet()
doPost()
所以一开始我想的是是不是配置出了问题 所以检查了一下web.xml配置文件 发现了没错
然后去看java代码 发现是有一个变量没有 没有new()
呃 虽然很智障 但是感觉java se的话 会主动报错这一行
报错
java.lang.NullPointerException
org.easybooks.test.servlet.MainServlet.doGet(MainServlet.java:30)
org.easybooks.test.servlet.MainServlet.doPost(MainServlet.java:78)
javax.servlet.http.HttpServlet.service(HttpServlet.java:661)
javax.servlet.http.HttpServlet.service(HttpServlet.java:742)
org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
- 第二个问题是一个感觉应该算的是常识问题
java.sql.date 转到 java.util.date
这里如果 直接 java.sql.date = java.util.date 会报错
为什么呢 查了一下资料 sql中 不支持分秒 而 util恰恰相反 是支持的
所以需要转变 但是强转也会出现相同报错
经过论坛上的老哥一阵开解 要用API(这是啥)上说的方法
ly.setDate( new java.sql.Date(new java.util.Date().getTime()));
再来说一个 错误的做法 我按照书上写的
ly.setDate(new Date(System.currentTimeMillis())); 呃 很经典的错法
type Exception Report
Message java.util.Date cannot be cast to java.sql.Date
Description The server encountered an unexpected condition that prevented it from fulfilling the request.
Exception
java.lang.ClassCastException: java.util.Date cannot be cast to java.sql.Date
org.easybooks.test.servlet.AddServlet.doGet(AddServlet.java:31)
org.easybooks.test.servlet.AddServlet.doPost(AddServlet.java:56)
javax.servlet.http.HttpServlet.service(HttpServlet.java:661)
javax.servlet.http.HttpServlet.service(HttpServlet.java:742)
org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
Note The full stack trace of the root cause is available in the server logs.
错误实例
- 第三个错误也比较智障 我在重写doGet的时候 是
public void doGet(HttpServletRequest request,HttpServletResponse response)
但是 在重写doPost的时候 很智障的把调用写反了 ... ... 多吃六个核桃补脑
public void doPost(HttpServletRequest request,HttpServletResponse response)
throws ServletException,IOException{
doGet(respose,request);
}
Type Status Report
Message HTTP method GET is not supported by this URL
Description The method received in the request-line is known by the origin server but not supported by the target resource.
错误实例
- 第四个其实是一个疑问 不过按照书上写炸了 然后 自己按照逻辑找出的错误
数据库里的
呃 先看代码
pstmt = conn.prepareStatement("insert into lytable values(?,?,?,?,?)");
pstmt.setInt(1,1);
pstmt.setInt(2,ly.getUserId());
pstmt.setDate(3,ly.getDate());
pstmt.setString(4,ly.getTitle());
pstmt.setString(5,ly.getContent());
pstmt.executeUpdate();
这是我试bug试出来没问题的代码
pstmt = conn.prepareStatement("insert into lytable values(?,?,?,?)");
pstmt.setInt(1,ly.getUserId());
pstmt.setDate(2,ly.getDate());
pstmt.setString(3,ly.getTitle());
pstmt.setString(4,ly.getContent());
pstmt.executeUpdate();
这是我出bug的代码
数据库设置
嗯 我把主键设为id 然后按了一个递增 书上并没有把这个写在预处理里面 所以我一开始认为是 可以从0递增 也就是说 我插入第一条 id = 1
嗯 然后 炸了 哭唧唧
接着 我自己多加了一个占位符 setInt(id) 嗯 成了
- 第五个也是一个疑问 关于 会话session的
HttpSession session = request.getSession();
UserTable userTable = (UserTable) session.getAttribute("userTable");
//建立lyTable信息
Integer userId = userTable.getId();
lyTable ly = new lyTable();
ly.setUserId(userId);
ly.setDate( new java.sql.Date(new java.util.Date().getTime()));
if(title!=null)System.out.println(title);
ly.setTitle(title);
ly.setContent(content);
//新添加的留言要保存一份到会话中 这种刷新主页时就无须每次都去查询数据库留言表了
ArrayList al = (ArrayList)session.getAttribute("al");
al.add(ly);
//没有放回去 也能 在main.jsp上看到
ArrayList al = (ArrayList)session.getAttribute("al");
al.add(ly);
//没有放回去 也能 在main.jsp上看到
// session.setAttribute("al",al);
我猜想是否是因为 引用的原因 修改发生在内存空间之中
所以之后 我不用在做一次
session.setAttribute("al",al);
就能成功放入(伪)
- 第6个问题 也算是一个未解决的bug吧 唔
在设置完al之后 塞到al之后 然后在main.jsp中看到是 null
问题可能是 main.jsp中调用错了 也可能是 传的时候传错了 这里应该看一下
数据库里的东西就知道了
数据库里 title的值是null
谨之慎之 巫妖再犯(= V =)
网友评论