SpringBoot使用注解进行分页的实现示例

作者:JavaGaga 时间:2021-08-21 22:45:32 

分页使用可以说非常普遍了,有时候会需要非常灵活的方式去开启或关闭分页,尝试使用一 * 解的方式来进行分页。

依赖安装

需要使用的依赖:

  • Mybatis-Plus

  • PageHelper

  • SpringBoot AOP

添加pom依赖

<!-- Mybatis-Plus -->
<dependency>
   <groupId>com.baomidou</groupId>
   <artifactId>mybatis-plus-boot-starter</artifactId>
   <version>3.4.3.4</version>
</dependency>
<!-- 分页 -->
<dependency>
   <groupId>com.github.pagehelper</groupId>
   <artifactId>pagehelper-spring-boot-starter</artifactId>
   <version>1.4.0</version>
</dependency>
<!-- AOP -->
<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-aop</artifactId>
   <version>2.5.5</version>
</dependency>

添加公共返回实体类

需要两种实体类,一种是不分页直接返回数据的,另一种是分页返回数据和总数据条数的

普通实体类 AjaxResult

@Data
@NoArgsConstructor
@AllArgsConstructor
public class AjaxResult<T> {

public static final int CODE_SUCCESS = 200;
   public static final int CODE_UNAUTHORIZED = 401;
   public static final int CODE_FORBIDDEN = 403;
   public static final int CODE_ERROR = 500;

public static final String MSG_SUCCESS = "操作成功";
   public static final String MSG_FAILED = "操作失败";
   public static final String MSG_NOT_PERMISSION = "用户权限不足";
   public static final String MSG_UNAUTHORIZED = "用户未登录或身份已过期";

private int code;
   private String msg;
   private T data;

public static <T> AjaxResult success(int code, T data) {
       return new AjaxResult(code, MSG_SUCCESS, data);
   }

public static <T> AjaxResult success(T data) {
       return success(CODE_SUCCESS, data);
   }

public static AjaxResult success() {
       return success(CODE_SUCCESS, null);
   }

public static AjaxResult error(int code, String msg) {
       return new AjaxResult(code, msg, null);
   }

public static AjaxResult error(String msg) {
       return error(CODE_ERROR, msg);
   }

public static AjaxResult error() {
       return new AjaxResult(CODE_ERROR, MSG_FAILED, null);
   }

}

分页实体类 PageResult

继承AjaxResult,额外添加total、pageNo和pageSize等字段

@Data
public class PageResult extends AjaxResult {

private long total;
   private long pageNo;
   private long pageSize;

public PageResult() {
       this.setCode(CODE_SUCCESS);
       this.setMsg(MSG_SUCCESS);
   }

public PageResult(AjaxResult ajaxResult) {
       this();
       if (Objects.nonNull(ajaxResult)) {
           setCode(ajaxResult.getCode());
           setMsg(ajaxResult.getMsg());
       }
   }
}

注解处理

分页注解 Pagination

创建一个用于分页的注解Pagination

其实这里的pageNo和pageSize没什么需求的话可以去掉的

/**
* 分页注解
*/
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
public @interface Pagination {

// 第几页的请求参数名称 通过获取参数名称获取真正的pageNo
   String pageNo() default "pageNo";
   // 分页大小的请求参数名称
   String pageSize() default "pageSize";

}

使用AOP进行分页

创建一个类用于处理分页注解,切入点要根据自己注解进行修改

@Aspect
@Component
@Slf4j
public class PaginationAspect {

/**
    * 定义切入点
    */
   @Pointcut("@annotation(cn.montaro.social.aspect.annotation.Pagination)")
   public void access() {

}

@SneakyThrows
   @Around("access()")
   public Object around(ProceedingJoinPoint joinPoint) {
       Object[] args = joinPoint.getArgs();
       Pagination pagination = getPaginationAnnotation(joinPoint);
       startPage(pagination.pageNo(), pagination.pageSize());
       // 调用原本方法的内容并获取返回值
       Object result = joinPoint.proceed(args);
       // 返回的数据类型要保证和注解方法上的一致
       return pageResult(result);
   }

/**
    * 获取Pagination注解
    *
    * @param joinPoint
    * @return
    */
   public Pagination getPaginationAnnotation(ProceedingJoinPoint joinPoint) {
       MethodSignature methodSignature = (MethodSignature) joinPoint.getSignature();
       Method method = methodSignature.getMethod();
       Pagination pagination = method.getAnnotation(Pagination.class);
       return pagination;
   }

/**
    * 开始分页
    */
   private void startPage(String pageNoParameterName, String pageSizeParameterName) {
       // 获取pageNo和pageSize
       int pageNo = ServletUtils.getParameterToInt(pageNoParameterName, 1);
       int pageSize = ServletUtils.getParameterToInt(pageSizeParameterName, 10);
       PageHelper.startPage(pageNo, pageSize);
   }

/**
    * 对分页结果进行包装 如果分页成功则会返回PageResult
    *
    * @param result
    */
   private Object pageResult(Object result) {
       /**
        * 如果分页成功,则查询返回的结应该是一个Page {@link com.github.pagehelper.Page}
        * 进行一次强制转换就能获取到 total、pageNo、pageSize 这些字段
        */
       PageInfo pageInfo = null;
       AjaxResult ajaxResult = null;
       // 列表数据 如果方法返回Page则直接使用 如果是AjaxResult则getData再封装
       Object list = null;
       if (result instanceof Page) {
           list = result;
           Page page = (Page) result;
           pageInfo = new PageInfo(page);
       } else if (result instanceof AjaxResult) {
           ajaxResult = (AjaxResult) result;
           Object data = ajaxResult.getData();
           if (data instanceof List) {
               list = data;
               pageInfo = new PageInfo((List) data);
           }
       }
       if (pageInfo != null) {
           PageResult pageResult = new PageResult(ajaxResult);
           pageResult.setData(list);
           pageResult.setPageNo(pageInfo.getPageNum());
           pageResult.setPageSize(pageInfo.getPageSize());
           pageResult.setTotal(pageInfo.getTotal());

return pageResult;
       }
       return result;
   }
}

还有注解中使用到的ServletUtils

public class ServletUtils {

public static HttpServletRequest getRequest() {
       ServletRequestAttributes requestAttributes = getRequestAttributes();
       return requestAttributes.getRequest();
   }

public static ServletRequestAttributes getRequestAttributes() {
       RequestAttributes requestAttributes = RequestContextHolder.getRequestAttributes();
       return (ServletRequestAttributes) requestAttributes;
   }

public static Integer getParameterToInt(String parameterName, Integer defaultValue) {
       HttpServletRequest request = getRequest();
       String strValue = request.getParameter(parameterName);
       Integer intValue = Convert.toInt(strValue, defaultValue);
       return intValue;
   }

public static Integer getParameterToInt(String parameterName) {
       return getParameterToInt(parameterName, null);
   }

}

使用注解

为了避免跑题,此处就省略mybatis-plus的使用了。

需要分页就加上@Pagination注解就行了,不需要就注释掉,代码完全不需要修改

分页的时候传入pageNo和pageSize参数就可以了,如果参数名需要更改,就修改@Pagination就可以了

编写Controller类

@RestController
@RequestMapping("/user")
public class UserController {

@Autowired
   private IUserService userService;

/**
    * 列出所有用户
    * @return
    */
   @Pagination
   @GetMapping("/list")
   public AjaxResult list(UserQueryReq query) {
       List<User> userList = userService.selectUserListByQuery(query);
       return AjaxResult.success(userList);
   }

}

测试

使用的Postman测试查看效果

使用注解的时候

SpringBoot使用注解进行分页的实现示例

把注解注释掉

SpringBoot使用注解进行分页的实现示例

来源:https://juejin.cn/post/7079661639078936589

标签:SpringBoot,注解,分页
0
投稿

猜你喜欢

  • SpringCloud整合Nacos实现流程详解

    2021-07-04 11:11:09
  • Springboot文件上传功能的实现

    2021-09-20 12:48:47
  • C#几种截取字符串的方法小结

    2023-07-16 09:55:10
  • TKmybatis的框架介绍和原理解析

    2022-08-28 21:35:42
  • Spring Boot 2.0.0 终于正式发布-重大修订版本

    2021-08-12 08:25:51
  • Java 实现常见的非对称加密算法

    2023-11-27 18:51:03
  • SpringBoot结合JSR303对前端数据进行校验的示例代码

    2022-09-15 03:22:55
  • C#计算字符串相似性的方法

    2022-08-18 11:32:15
  • Java设计模式之单例和原型

    2023-11-29 04:14:18
  • 简单了解Spring beanfactory循环依赖命名重复属性

    2023-10-27 19:39:14
  • Springboot整合mqtt服务的示例代码

    2022-07-20 02:58:01
  • Java非侵入式API接口文档工具apigcc用法详解

    2023-11-24 10:01:00
  • 实例讲解Java读取一般文本文件和word文档的方法

    2023-11-13 05:09:53
  • 如何利用Spring把元素解析成BeanDefinition对象

    2023-11-23 05:17:16
  • 浅谈java 面对对象(抽象 继承 接口 多态)

    2022-04-01 07:23:50
  • Java实现调用外部程序的示例代码

    2023-11-10 06:43:12
  • Maven的安装配置详解

    2023-11-24 08:52:05
  • java实现登录验证码功能

    2021-06-08 19:34:18
  • 基于java构造方法Vector创建对象源码分析

    2023-11-25 11:27:54
  • 详解Kotlin:forEach也能break和continue

    2022-05-03 01:24:10
  • asp之家 软件编程 m.aspxhome.com