SpringMVC(16) —— SSM整合:查询书籍功能

  • 通过前面的ssm整合,其实我们的dao层、service层已经搭建好了,所以现在要实现需求就差实现controller层和视图了
  • 我们现在实现controller

0.分析

  • 首先实现controller调用service获取全部数据的list数据
  • 然后controller指定视图名称,并将list一并返回给dispatcherservlet,由dispatcherservlet将它传给视图解析器,视图解析器获取视图名称拼接视图正真的URL即可找到对应的视图
  • 视图解析器将视图和数据结合/渲染数据,将渲染结果返回给dispatcherservlet
  • 最后dispatcherservlet将渲染好的视图返回给用户

1.代码实现

1.controller

package com.thhh.controller;

import com.thhh.pojo.Books;
import com.thhh.service.BookService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;

import java.util.List;

@Controller
@RequestMapping("book")
public class BookController {
    
    //controller层调用service层
    @Autowired
    @Qualifier("BookServiceImpl")    //配合@Autowired使用,用于指定一个id的bean来自动装配这个对象属性
    BookService service;
    
    @RequestMapping("/allBook")
    public String queryBookList(Model model){
        List<Books> bookList = service.queryBookList();
        model.addAttribute("list",bookList);
        return "allBook";
    }
}

    上面就写完了查询全部书籍的controller了,接下来就是写对应的视图用于展示数据了

2.视图

  • 创建上面controller跳转的视图allBook.jsp
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>Title</title>
</head>
<body>
<h3>书籍列表</h3>
</body>
</html>
  • 在首页写一个a标签跳转allBook.jsp页面
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
  <head>
    <title>$Title$</title>
  </head>
  <body>
  <a href="${pageContext.request.contextPath}/book/allBook">查询所有书籍</a>
  </body>
</html>
  • 测试一下能不能跳转
    在这里插入图片描述
  • 美化页面
    首先美化一下首页
    <%@ page contentType="text/html;charset=UTF-8" language="java" %>
    <html>
     <head>
       <title>$Title$</title>
       <style>
    
         h3{
           width: 180px;
           height: 38px;
           margin: 100px auto;/*外边距上下100,左右自动*/
           text-align: center;/*文字左右居中*/
           line-height: 38px;/*文字上下居中,直接让字体高度 = 元素高度即可*/
           background: cornflowerblue;
           border-radius: 5px;/*圆角边框*/
         }
         a{
           text-decoration: none;/*去掉下划线*/
           color: black;
           font-size: 18px;
         }
       </style>
     </head>
     <body>
    <h3><a href="${pageContext.request.contextPath}/book/allBook">查询所有书籍</a></h3>
     </body>
    </html>
    

在这里插入图片描述
接下来美化数据展示页面,这里我们直接使用bootstrap来设置样式;要展示的数据后端已经通过model传输过来了,所以我们变量list集合,就是要JSTL标签c:foreach

<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
   <title>Title</title>
   <%--bootstrap--%>
   <%--直接在线引入css文件--%>
   <link href="https://cdn.staticfile.org/twitter-bootstrap/3.3.7/css/bootstrap.min.css" rel="stylesheet">
</head>
<body>
   <div class="container"><%--栅格系统--%>
       <div class="row clearfix">
           <div class="col-md-12 column"><%--将屏幕分为12份--%>
               <div class="page-header">
                   <h1>
                       <small>书籍列表——显示所有书籍数据</small>
                   </h1>
               </div>
           </div>
       </div>

       <div class="row clearfix">
           <div class="col-md-12 column">
               <table class="table table-hover table-striped">
                   <thead>
                       <tr>
                           <th>书籍编号</th>
                           <th>书籍名称</th>
                           <th>书籍数量</th>
                           <th>书籍详情</th>
                       </tr>
                   </thead>

                   <tbody>
                       <c:forEach var="book" items="${list}">
                       <tr>
                           <td>${book.bookID}</td>
                           <td>${book.bookName}</td>
                           <td>${book.bookCounts}</td>
                           <td>${book.detail}</td>
                       </tr>
                       </c:forEach>
                   </tbody>
               </table>
           </div>

       </div>
   </div>

</body>
</html>

在这里插入图片描述

  • 数据展示

3.BUG

  • 发布的项目没有依赖
    在这里插入图片描述

在这里插入图片描述

  • 自定装配失败/web.xml中spring配置文件绑定错误
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
  • spring配置文件中有中文注释
        将所有配置文件中的UTF-8改为UTF8,是所有的,包括mybatis核心配置文件
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
[ 2021年,将Spring全家桶的课程进行Review,确保不再有顺序错乱等问题导致学员看不懂内容,进入2022年,将Spring的课程进行整理,整理为案例精讲的系列课程,并开始逐步增加高阶的Spring Security等内容,课件将逐步进行上传,敬请期待! ]本课程是Spring全家桶案例精讲课程的第二部分Spring MVC,Spring案例精讲课程以真实场景、项目实战为导向,循序渐进,深入浅出的讲解Java网络编程,助力您在技术工作更进一步。 本课程聚焦Java Spring的Web知识点,主要是关于Spring MVC的应用,包含:表单的增删改查、国际化、过滤器、拦截器、日志Log4j2及slf4j的使用、主题更改网站皮肤及样式、文件上传等的案例讲解,并且最后以一个SSM(Spring+Spring MVC+Mybatis)贯穿前后台的案例作为Spring MVC课程的终奖, 从而使大家快速掌握Spring的基础核心知识,快速上手,为面试、工作等做好充足准备。 由于本课程聚焦于案例,即直接上手操作,对于Spring的原理等不会做过多介绍,希望了解原理等内容的需要通过其他视频或者书籍去了解,建议按照该案例课程一步步做下来,之后再去进一步回顾原理,这样能够促进大家对原理有更好的理解。 【通过Spring全家桶,我们保证你能收获到以下几点】 1、掌握Spring全家桶主要部分的开发、实现2、可以使用Spring MVC、Spring Boot、Spring Cloud及Spring Data进行大部分的Spring开发3、初步了解使用微服务、了解使用Spring进行微服务的设计实现4、奠定扎实的Spring技术,具备了一定的独立开发的能力  【实力讲师】 毕业于清华大学软件学院软件工程专业,曾在Accenture、IBM等知名外企任管理及架构职位,近15年的JavaEE经验,近8年的Spring经验,一直致力于架构、设计、开发及管理工作,在电商、零售、制造业等有丰富的项目实施经验 【本课程适用人群】如果你是一定不要错过!  适合于有JavaEE基础的,如:JSP、JSTL、Java基础等的学习者没有基础的学习者跟着课程可以学习,但是需要补充相关基础知识后,才能很好的参与到相关的工作。 【Spring全家桶课程共包含如下几门】 

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值