Java简单实现SpringMVC+MyBatis分页插件

Java简单实现SpringMVC+MyBatis分页插件

环境准备

在开始之前,需要确保以下环境已经准备好:

  • JDK 1.8或以上版本
  • Maven 3.0或以上版本
  • Tomcat 8.0或以上版本
  • IntelliJ IDEA 2018或以上版本

创建Maven项目

  1. 打开IntelliJ IDEA,选择“Create New Project”。
  2. 在弹出的窗口中选择“Maven”项目类型,并勾选“Create from archetype”选项。
  3. 在下拉列表中选择“maven-archetype-webapp”。
  4. 输入项目的GroupId、ArtifactId和Version等信息,然后点击“Next”。
  5. 在下一步中,选择项目的存储路径和项目名称,然后点击“Finish”按钮。

导入依赖

在pom.xml文件中添加以下依赖:

<dependencies>
  <!-- Spring -->
  <dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-context</artifactId>
    <version>5.2.0.RELEASE</version>
  </dependency>
  <dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-web</artifactId>
    <version>5.2.0.RELEASE</version>
  </dependency>
  <dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-webmvc</artifactId>
    <version>5.2.0.RELEASE</version>
  </dependency>
  <!-- MyBatis -->
  <dependency>
    <groupId>org.mybatis</groupId>
    <artifactId>mybatis</artifactId>
    <version>3.5.4</version>
  </dependency>
  <dependency>
    <groupId>org.mybatis</groupId>
    <artifactId>mybatis-spring</artifactId>
    <version>2.0.4</version>
  </dependency>
  <!-- 数据库驱动 -->
  <dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>8.0.22</version>
  </dependency>
  <!-- Servlet API -->
  <dependency>
    <groupId>javax.servlet</groupId>
    <artifactId>javax.servlet-api</artifactId>
    <version>4.0.1</version>
    <scope>provided</scope>
  </dependency>
  <!-- 分页插件 -->
  <dependency>
    <groupId>com.github.pagehelper</groupId>
    <artifactId>pagehelper</artifactId>
    <version>5.2.0</version>
  </dependency>
</dependencies>

配置Spring

在src/main/resources目录下创建一个名为“applicationContext.xml”的Spring配置文件,并添加以下内容:

<!-- 配置数据源 -->
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
  <property name="driverClassName" value="com.mysql.cj.jdbc.Driver"/>
  <property name="url" value="jdbc:mysql://localhost:3306/test?useSSL=false&amp;serverTimezone=UTC"/>
  <property name="username" value="root"/>
  <property name="password" value="123456"/>
</bean>

<!-- 配置MyBatis -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
  <property name="dataSource" ref="dataSource"/>
  <property name="mapperLocations" value="classpath:mapper/*.xml"/>
</bean>

<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
  <property name="basePackage" value="com.example.mapper"/>
</bean>

在上面的配置中,我们配置了数据源和MyBatis的SqlSessionFactory。同时,我们还配置了MapperScannerConfigurer来扫描Mapper接口。

配置Spring MVC

在src/main/webapp/WEB-INF目录下创建一个名为“springmvc-servlet.xml”的Spring MVC配置文件,并添加以下内容:

<!-- 配置Spring MVC -->
<bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
  <property name="prefix" value="/WEB-INF/views/"/>
  <property name="suffix" value=".jsp"/>
</bean>

<!-- 配置扫描Controller -->
<context:component-scan base-package="com.example.controller"/>

在上面的配置中,我们配置了视图解析器和扫描Controller。

配置web.xml

在src/main/webapp/WEB-INF目录下创建一个名为“web.xml”的web配置文件,并添加以下内容:

<!-- 配置DispatcherServlet -->
<servlet>
  <servlet-name>springmvc</servlet-name>
  <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
  <init-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>classpath:springmvc-servlet.xml</param-value>
  </init-param>
  <load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
  <servlet-name>springmvc</servlet-name>
  <url-pattern>/</url-pattern>
</servlet-mapping>

在上面的配置中,我们配置了DispatcherServlet,并将其映射到根路径。

创建Controller

在src/main/java目录下创建一个名为“com.example.controller”的包,并在其中创建一个名为“UserController”的类。在该类中添加以下内容:

@Controller
@RequestMapping("/user")
public class UserController {
  @Autowired
  private UserService userService;

  @GetMapping("/list")
  public String getUserList(@RequestParam(defaultValue = "1") int pageNum, Model model) {
    PageHelper.startPage(pageNum, 10);
    List<User> userList = userService.getUserList();
    PageInfo<User> pageInfo = new PageInfo<>(userList);
    model.addAttribute("userList", userList);
    model.addAttribute("pageInfo", pageInfo);
    return "userList";
  }
}

在上面的代码中,我们创建了一个名为“UserController”的Controller,并使用@GetMapping注解来处理GET请求。在方法中,我们使用@RequestParam注解来获取请求参数,并使用@Autowired注解来注入UserService。我们使用PageHelper.startPage方法来开启分页功能,并设置每页显示10条记录。然后,我们调用UserService的getUserList方法来获取用户列表,并使用PageInfo来封装分页信息。最后,我们将查询到的User列表和分页信息添加到Model中,并返回“userList”视图。

创建Mapper

在src/main/java目录下创建一个名为“com.example.mapper”的包,并在其中创建一个名为“UserMapper”的接口。在该接口中添加以下内容:

public interface UserMapper {
  List<User> getUserList();
}

在上面的代码中,我们创建了一个名为“UserMapper”的Mapper接口,并定义了一个名为“getUserList”的方法。

创建Service

在src/main/java目录下创建一个名为“com.example.service”的包,并在其中创建一个名为“UserService”的接口。在该接口中添加以下内容:

public interface UserService {
  List<User> getUserList();
}

在上面的代码中,我们创建了一个名为“UserService”的Service接口,并定义了一个名为“getUserList”的方法。

在src/main/java目录下创建一个名为“com.example.service.impl”的包,并在其中创建一个名为“UserServiceImpl”的类。在该类中添加以下内容:

@Service
public class UserServiceImpl implements UserService {
  @Autowired
  private UserMapper userMapper;

  @Override
  public List<User> getUserList() {
    return userMapper.getUserList();
  }
}

在上面的代码中,我们创建了一个名为“UserServiceImpl”的Service实现类,并使用@Autowired注解来注入UserMapper。在getUserList方法中,我们调用UserMapper的getUserList方法来查询用户列表。

创建JSP视图

在src/main/webapp/WEB-INF/views目录下创建一个名为“userList.jsp”的JSP视图,并添加以下内容:

<!DOCTYPE html>
<html>
<head>
  <title>User List</title>
</head>
<body>
  <h1>User List</h1>
  <table>
    <thead>
      <tr>
        <th>ID</th>
        <th>Name</th>
        <th>Age</th>
      </tr>
    </thead>
    <tbody>
      <c:forEach items="${userList}" var="user">
        <tr>
          <td>${user.id}</td>
          <td>${user.name}</td>
          <td>${user.age}</td>
        </tr>
      </c:forEach>
    </tbody>
  </table>
  <div>
    <ul>
      <li><a href="?pageNum=1">首页</a></li>
      <li><a href="?pageNum=${pageInfo.prePage}">上一页</a></li>
      <li><a href="?pageNum=${pageInfo.nextPage}">下一页</a></li>
      <li><a href="?pageNum=${pageInfo.pages}">尾页</a></li>
    </ul>
  </div>
</body>
</html>

在上面的代码中,我们创建了一个名为“userList.jsp”的JSP视图,并使用标签来循环显示用户列表。同时,我们使用PageInfo对象来显示分页信息,并使用超链接来实现分页功能。

运行项目

在完成以上步骤后,我们可以启动Tomcat服务器,并访问http://localhost:8080/user/list来查看用户列表。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Java简单实现SpringMVC+MyBatis分页插件 - Python技术站

(0)
上一篇 2023年5月18日
下一篇 2023年5月18日

相关文章

  • Maven中央仓库发布的实现方法

    Maven中央仓库发布的实现方法 Maven是一款非常流行的Java项目管理工具,通过Maven可以方便地进行依赖管理、编译打包、文档生成等工作。而Maven中央仓库是Maven默认的插件和依赖库存储服务,包含了数百万个开源库和插件。 为了方便大家将自己的Java项目发布到Maven中央仓库,本文将介绍一种基于Sonatype Nexus Repositor…

    Java 2023年5月19日
    00
  • springboot @RequestBody 接收字符串实例

    下面我来详细讲解”springboot @RequestBody 接收字符串实例”的完整攻略。 1. @RequestBody 简介 @RequestBody注解用于接收前端发送的请求体数据,常用于POST请求中。使用该注解可以让SpringBoot自动将请求体转化为方法的参数。 2. 使用步骤 接收字符串类型的@RequestBody,主要有以下两个步骤:…

    Java 2023年5月27日
    00
  • hibernate 中 fetch=FetchType.LAZY 懒加载失败处理方法

    下面是我对“hibernate 中 fetch=FetchType.LAZY 懒加载失败处理方法”的完整攻略。 1. 什么是 fetch=FetchType.LAZY 懒加载? 在 Hibernate 中,fetch 是控制语句 load 与 get 的机制的一个选项。fetch = FetchType.LAZY 就是懒加载模式。它是指当我们使用 Hiber…

    Java 2023年5月20日
    00
  • Java SpringBoot实现带界面的代码生成器详解

    Java Spring Boot实现带界面的代码生成器详解 在Java开发中,代码生成器是一种非常常见的工具,可以帮助我们快速生成代码,提高开发效率。本文将手把手教你如何使用Spring Boot实现带界面的代码生成器,包括选择代码生成器、配置代码生成器、使用代码生成器等。 1. 选择代码生成器 在Java开发中,有很多代码生成器可供选择,比如MyBatis…

    Java 2023年5月14日
    00
  • java使用多线程找出最大随机数

    找出最大随机数这一问题可以使用多线程来优化程序的效率和性能。Java提供了多种实现多线程的方法,本文将介绍如何使用Java多线程来寻找最大随机数。 1.使用Runnable接口 使用Runnable接口是实现多线程的最简单方法之一。Java中的Runnable接口定义了一个run()方法,当线程启动时该方法会被执行。我们可以通过实现Runnable接口并实现…

    Java 2023年5月19日
    00
  • java 如何从字符串里面提取时间

    提取字符串中的时间可以分为两步:1)识别时间字符串,2)将时间字符串转为java.util.Date或java.time.LocalDateTime等日期时间对象。 识别时间字符串 Java提供了多种方式来识别时间字符串,比如使用正则表达式或者使用第三方库。下面是两条示例: 使用正则表达式 import java.util.regex.Matcher; im…

    Java 2023年5月20日
    00
  • SpringBoot之自定义Banner详解

    Spring Boot 之自定义 Banner 详解 在本文中,我们将深入了解 Spring Boot 中自定义 Banner 的使用。我们将介绍 Banner 的概念、配置和使用,并提供两个示例。 Banner 概念 Banner 是指在应用程序启动时显示的 ASCII 艺术字或自定义文本。Spring Boot 默认提供了一个 Banner,它包含了 S…

    Java 2023年5月15日
    00
  • Spring深入了解常用配置应用

    Spring深入了解常用配置应用攻略 Spring是当前Java开发中最受欢迎的框架之一,其中最大的优势是依赖注入和面向切面编程。Spring的核心是控制反转(IoC)和注释驱动的依赖注入(DI)。本文将深入了解Spring的常用配置应用,其中包括: Spring XML配置文件 Spring注解配置 Spring Boot自动配置 Spring XML配置…

    Java 2023年5月19日
    00
合作推广
合作推广
分享本页
返回顶部