你的位置:首页 > Java教程

[Java教程]用JSP做后台管理系统


突然很开心,紧张了好几天的项目终于不那么赶了。

我是一个比别人慢半拍的人,所以一定要比别人多付出一点努力。

今天在进行添加新闻的时候发现可扩展的还有好多,可惜也只能是脑子里有东西,但都不知道应该怎么做(但愿不会忘,等下次学习之后还会回过头来做这件事)。

 

顺便说一下今天犯的错误。

在进行添加新闻时,纠结了好久。

/**
  * 获取从页面读取的数据
  * @param request
  * @return 单个新闻信息
  * @throws UnsupportedEncodingException
  */
 private News getNews(HttpServletRequest request) throws UnsupportedEncodingException {
  request.setCharacterEncoding("UTF-8");
  //读取用户选择的是哪一个主题ID
  String id = request.getParameter("topic");
  //把值转换为Int类型 传给 Topic实体类
  Topic topic = new Topic(Integer.parseInt(id));
  //标题
  String title = request.getParameter("title");
  //作者
  String author = request.getParameter("author");
  //摘要
  String summary = request.getParameter("summary");
  //内容
  String ncontent = request.getParameter("ncontent");
  
  News news = new News(topic,title,author,summary,ncontent); 
  
  return news;
 }

 /**
  * 添加新闻
  */
 public void addNews(HttpServletRequest request, HttpServletResponse response)
 throws ServletException, IOException {
  boolean b = ndi.addNews(getNews(request));  
  if( b){
   selectNews(request, response);
   }else{
    request.setAttribute("errorInfo", "新闻添加失败!");
    request.getRequestDispatcher("error.jsp").forward(request, response); 
   }
 }

下面详细说为什么获取错了。

第一步:

  我先手动从数据库往表中添加数据,结果发现可以。但是不能执行。

第二步:

  我修改了要添加进news实体类中的值,改为了字符串而并非是页面的内容,结果上面显示说,有FK约束。还是不能执行。

第三步:

  终于知道错误所在了,好开心。然后就把我之前建错的外键约束给改了。

  t_news : id ==t_topic : id ---> t_news : tid == t_topic : id

  因为我把两个表中的主键给关联一起了,所以就不能执行。改成新闻表中的主题ID列与主题表中的ID列相对应就可以了。结果发现还是不能执行。

第四步:

  又跳转到页面上,发现我竟然没有给下拉菜单个名字!!

  唉,真是粗心大意的我啊。然后想起了教员所谓的要让程序找到你的下拉框才能给值,于是就给了id。

  这样应该就行了吧。结果还是不行。

第五步:

  头昏昏的,看来我是真的做不出来了。然后叫了教员问为什么。他就看了一眼,说了句:

  <%--想要获取select的value值,就需要给他一个名字。切记:用name而非id,ID是唯一的,适用于CSS,name利于后台获取 --%>

  呵呵,原来如此,不是id而是name啊。
     <select name="topic">
      <c:forEach items="${topicList}" var="topic">      
       <option value="${topic.id}" />${topic.tname}
      </c:forEach>    
      </select>

 

 

这个项目终于能见睁眼了,好开心。看着自己创造出来的东西,真心幸福。

最后告诫我一句,调试真的很重要,英语单词真的很重要,课外知识真的很重要。