JavaEE框架技术

彭红伟、骆丽华、李康顺、聂鹏、袁大伟、孟雨、王诗雅、张新伟、聂军、谢备

目录

  • 1 初识MyBatis框架
    • 1.1 框架概述
    • 1.2 框架的优势
    • 1.3 当前主流框架
    • 1.4 传统JDBC的劣势
    • 1.5 MyBatis概述
    • 1.6 MyBatis环境搭建
    • 1.7 MyBatis入门程序
    • 1.8 MyBatis工作原理
    • 1.9 扩展阅读
    • 1.10 章节测试
  • 2 MyBatis的核心配置
    • 2.1 SqlSessionFactoryBuilder对象
    • 2.2 SqlSessionFactory对象
    • 2.3 SqlSession对象
    • 2.4 MyBatis配置文件的主要元素
    • 2.5 <properties>元素
    • 2.6 <settings>元素
    • 2.7 <typeAliases>元素
    • 2.8 <environments>元素
    • 2.9 <mappers>元素
    • 2.10 MyBatis映射文件中的常用元素
    • 2.11 <select>元素
    • 2.12 <insert>元素
    • 2.13 <update>元素
    • 2.14 <delete>元素
    • 2.15 <sql>元素
    • 2.16 <resultMap>元素
    • 2.17 案例:员工管理系统
    • 2.18 扩展阅读
    • 2.19 章节测试
  • 3 动态SQL
    • 3.1 动态SQL中的元素
    • 3.2 <if>元素
    • 3.3 <choose>、<when>、<otherwise>元素
    • 3.4 <where>元素
    • 3.5 <trim>元素
    • 3.6 更新操作
    • 3.7 <foreach>元素中的属性
    • 3.8 <foreach>元素迭代数组
    • 3.9 <foreach>元素迭代List
    • 3.10 <foreach>元素迭代Map
    • 3.11 案例:学生信息查询系统
    • 3.12 扩展阅读
    • 3.13 章节测试
  • 4 MyBatis的关联映射和缓存机制
    • 4.1 关联映射概述
    • 4.2 一对一查询
    • 4.3 一对多查询
    • 4.4 多对多查询
    • 4.5 一级缓存
    • 4.6 二级缓存
    • 4.7 案例:商品的类别
    • 4.8 扩展阅读
    • 4.9 章节测试
  • 5 MyBatis的注解开发
    • 5.1 @Select注解
    • 5.2 @Insert注解
    • 5.3 @Update注解
    • 5.4 @Delete注解
    • 5.5 @Param注解
    • 5.6 一对一查询
    • 5.7 一对多查询
    • 5.8 多对多查询
    • 5.9 案例:基于MyBatis注解的学生 管理程序
    • 5.10 扩展阅读
    • 5.11 章节测试
  • 6 初识Spring框架
    • 6.1 Spring概述
    • 6.2 Spring框架的优点
    • 6.3 Spring的体系结构
    • 6.4 Spring 5的新特性
    • 6.5 Spring的下载及目录结构
    • 6.6 Spring的入门程序
    • 6.7 控制反转的概念
    • 6.8 依赖注入的概念
    • 6.9 依赖注入的类型—构造方法注入
    • 6.10 依赖注入的类型—属性setter方法注入
    • 6.11 依赖注入的应用
    • 6.12 扩展阅读
    • 6.13 章节测试
  • 7 Spring中的Bean的管理
    • 7.1 BeanFactory接口
    • 7.2 ApplicationContext接口
    • 7.3 Bean的配置
    • 7.4 构造方法实例化
    • 7.5 静态工厂实例化
    • 7.6 实例工厂实例化
    • 7.7 singleton作用域
    • 7.8 prototype作用域
    • 7.9 基于XML的装配
    • 7.10 基于注解的装配
    • 7.11 自动装配
    • 7.12 Bean的生命周期
    • 7.13 扩展阅读
    • 7.14 章节测试
  • 8 Spring AOP
    • 8.1 Spring AOP概述
    • 8.2 Spring AOP术语
    • 8.3 JDK动态代理
    • 8.4 CGLib动态代理
    • 8.5 基于XML的AOP实现
    • 8.6 基于注解的AOP实现
    • 8.7 扩展阅读
    • 8.8 章节测试
  • 9 Spring的数据库编程
    • 9.1 JdbcTemplate概述
    • 9.2 Spring JDBC的配置
    • 9.3 excute()方法
    • 9.4 update()方法
    • 9.5 query()方法
    • 9.6 事务管理的核心接口
    • 9.7 事务管理的方式
    • 9.8 基于XML方式的声明式事务
    • 9.9 基于注解方式的声明式事务
    • 9.10 案例:实现用户登录
    • 9.11 扩展阅读
    • 9.12 章节测试
  • 10 初识Spring MVC框架
    • 10.1 Spring MVC概述
    • 10.2 Spring MVC特点
    • 10.3 Spring MVC入门程序
    • 10.4 Spring MVC工作原理
    • 10.5 扩展阅读
    • 10.6 章节测试
  • 11 Spring MVC的核心类和注解
    • 11.1 DispatcherServlet类
    • 11.2 @Controller注解
    • 11.3 @RequestMapping注解的使用
    • 11.4 @RequestMapping注解的属性
    • 11.5 请求映射方式
    • 11.6 扩展阅读
    • 11.7 章节测试
  • 12 Spring MVC数据绑定和相应
    • 12.1 数据绑定
    • 12.2 默认类型数据绑定
    • 12.3 简单数据类型绑定
    • 12.4 POJO绑定
    • 12.5 自定义类型转换器
    • 12.6 数组绑定
    • 12.7 集合绑定
    • 12.8 复杂POJO绑定—属性为对象类型的数据绑定
    • 12.9 复杂POJO绑定—属性为List类型的数据绑定
    • 12.10 复杂POJO绑定—属性为Map类型的数据绑定
    • 12.11 JSON数据绑定
    • 12.12 返回值为void类型的页面跳转
    • 12.13 返回值为String类型的页面跳转—不携带数据
    • 12.14 返回值为String类型的页面跳转—携带数据
    • 12.15 返回值为ModelAndView类型的页面跳转
    • 12.16 普通字符串的回写
    • 12.17 JSON数据的回写—对象数据转换成JSON数据后的回写
    • 12.18 JSON数据的回写—集合数据转换成JSON数据后的回写
    • 12.19 扩展阅读
    • 12.20 章节测试
  • 13 Spring MVC的高级功能
    • 13.1 简单异常处理器
    • 13.2 自定义异常处理器
    • 13.3 异常处理注解
    • 13.4 拦截器概述
    • 13.5 拦截器的配置
    • 13.6 拦截器的执行流程—单个拦截器
    • 13.7 拦截器的执行流程—多个拦截器
    • 13.8 案例:后台系统登录验证
    • 13.9 文件上传
    • 13.10 文件下载
    • 13.11 案例:文件上传和下载
    • 13.12 扩展阅读
    • 13.13 章节测试
  • 14 SSM框架整合
    • 14.1 常用方式整合思路
    • 14.2 项目基础结构搭建
    • 14.3 Spring和MyBatis整合
    • 14.4 Spring和Spring MVC整合
    • 14.5 纯注解方式整合思路
    • 14.6 纯注解SSM框架整合
    • 14.7 扩展阅读
    • 14.8 章节测试
  • 15 云借阅图书管理系统
    • 15.1 系统概述
    • 15.2 数据库设计
    • 15.3 系统环境搭建
    • 15.4 用户登录
    • 15.5 实现登录验证
    • 15.6 注销登录
    • 15.7 新书推荐
    • 15.8 图书借阅
    • 15.9 当前借阅
    • 15.10 借阅记录
    • 15.11 访问权限控制
    • 15.12 扩展阅读
    • 15.13 章节测试
图书借阅

★学习目标:

1、掌握云借阅系统的图书借阅

★思考任务:

1、图书借阅有那些功能?

★任务学习:

★知识要点:

   图书借阅模块包括查询图书、新增图书、编辑图书和借阅图书这4个功能,其中,图书借阅功能和新书推荐模块中的图书借阅功能执行的是同样的代码,在此,就不进行重复讲解。新增图书和编辑图书是管理员角色才有的权限,当普通用户登录时,不会展示和开放对应的功能。接下来,分别对查询图书、新增图书和编辑图书这3个功能的实现进行讲解。

1、查询图书

查询图书时,用户可以根据条件查询所有未下架的图书信息,如果没有输入查询条件,就查询所有图书信息。由于数据库中的数据可能有很多,如果让这些数据在一个页面中全部显示出来,势必会使页面数据的可读性变得很差,所以本系统将查询的数据进行分页,每页默认展示10条数据。 

登录系统后,在浏览器中输入地址http://localhost:8080/cloudlibrary/admin/books.jsp,访问图书借阅页面

step 1:实现DAO层:由于不能预测用户是有条件查询还是无条件查询,查询时候统一将查询条件封装到Book对象中,最后根据查询条件是否为空进行查询语句的动态拼接。在BookMapper接口中新增查询方法searchBooks()。 

@Select({"<script>" +

        "SELECT * FROM book " +"where book_status !='3'" +

        "<if test=\"name != null\"> 

              AND  book_name  like  CONCAT('%',#{name},'%')</if>" +

        "<if test=\"press != null\"> 

              AND book_press like  CONCAT('%', #{press},'%') </if>" +

        "<if test=\"author != null\"> 

              AND book_author like  CONCAT('%', #{author},'%')</if>" +"order by book_status" +"</script>” })

@ResultMap("bookMap")

Page<Book> searchBooks(Book book); // 查询图书

step 2:实现Service层:在文件BookService.java的BookService接口中新增查询图书的方法search(),具体代码如下所示。

//分页查询图书

PageResult search(Book book, 

Integer pageNum, Integer pageSize);

在BookServiceImpl类中重写BookService接口的search()方法,具体代码如下所示。

public PageResult search(Book book, Integer pageNum, Integer pageSize){

    // 设置分页查询的参数,开始分页

    PageHelper.startPage(pageNum, pageSize);

    Page<Book> page=bookMapper.searchBooks(book);

    return new PageResult(page.getTotal(),page.getResult());

step 3:实现Controller:在BookController类中新增查询图书的方法search(),该示例代码省略。

step 4:实现页面效果:在后台首页main.jsp的导航侧栏中,配置“图书借阅”超链接的目标路径,配置代码如下所示。

<li >

    <a href="${pageContext.request.contextPath}/book/search"

   target="iframe">

        <i class="fa fa-circle-o"></i>图书借阅

    </a>

</li>

step 5:启动项目,使用管理员账号登录系统,单击导航侧栏的“图书借阅”超链接,页面显示。

2、新增图书

step 1:增图书功能的具体实现步骤如下。实现DAO层:在BookMapper接口中新增一个新增图书的方法addBook(),新增后的文件内容如下所示。

/新增图书

Integer addBook(Book book);

在BookMapper.xml映射文件中,使用<insert>元素编写新增图书的语句,具体代码如下所示。 

<insert id="addBook" parameterType="com.itheima.domain.Book">

insert into book(

book_id,book_name,book_isbn,book_press,book_author,

book_pagination,book_price,book_uploadtime,book_status,

book_borrower,book_borrowtime,book_returntime)

values (#{id},#{name},#{isbn},#{press},#{author},#{pagination},

#{price},#{uploadTime},#{status},#{borrower},#{borrowTime},#{returnTime})</insert>

step 2:实现Service层:在BookService接口中添加新增图书的方法addBook(),具体代码如下所示。

//新增图书

Integer addBook(Book book);

在BookServiceImpl类中重写BookService接口的addBook()方法,具体代码如下所示。

public Integer addBook(Book book) {

    DateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");

    //设置新增图书的上架时间

    book.setUploadTime(dateFormat.format(new Date()));

    return  bookMapper.addBook(book);

}

step 3:实现Controller:在BookController类中新增一个新增图书的方法addBook(),新增addBook()方法的代码如下所示。

@ResponseBody

@RequestMapping("/addBook")

public Result addBook(Book book) {

    try {

        Integer count=bookService.addBook(book);

        if(count!=1) { return new Result(false, "新增图书失败!"); }

        return new Result(true, "新增图书成功!");

    } catch (Exception e) {

        e.printStackTrace();

        return new Result(false, "新增图书失败!"); }}

step 4:实现页面效果:


3、编辑图书

step 1:实现DAO层:由于编辑图书和之前实现的图书借阅类似,都是将当前操作的图书信息进行更新,所以编辑图书无须在BookMapper接口中新增方法,可以直接复用BookMapper接口中的editBook()方法即可。

step 2:实现Service层:在BookService接口中添加新增图书的方法editBook(),具体代码如下所示。

/编辑图书信息

Integer editBook(Book book);

在BookServiceImpl类中重写BookService接口的editBook()方法,具体代码如下所示。 

public Integer editBook(Book book) {

    return bookMapper.editBook(book);

}

step 3:实现Controller:在BookController类中新增一个编辑图书的方法editBook(),新增editBook()方法的代码如下所示。 

@ResponseBody

@RequestMapping("/editBook")

public Result editBook(Book book) {

    try {

        Integer count= bookService.editBook(book);

        if(count!=1) { return new Result(false, "编辑失败!"); }

        return new Result(true, "编辑成功!");

    } catch (Exception e) {

        e.printStackTrace();

        return new Result(false, "编辑失败!"); }}

step 4:实现页面效果: